Trình bày được khái niệm và các đặc điểm của hệ thống
proxy.
Giải thích được các thông số cấu hình của squid.
Cấu hình được squid hoạt động ở chế độ cache và
transparent.
Nhận biết hệ thống firewall dùng iptables.
Giải thích các thông số của iptables.
Cấu trúc lệnh của iptables.
Triển khai firewall dùng iptables.
38 trang |
Chia sẻ: lylyngoc | Lượt xem: 1869 | Lượt tải: 1
Bạn đang xem trước 20 trang tài liệu Bài 7: Bảo mật hệ thống Linux, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
MH/MĐ: QUẢN TRỊ MẠNG LINUX
Bài 1: TRIỂN KHAI VÀ QUẢN TRỊ HỆ ĐIỀU HÀNH LINUX
Bài 2: QUẢN TRỊ TÀI KHOẢN NGƯỜI DÙNG VÀ LẬP TRÌNH
SHELL
Bài 3: TRIỂN KHAI DỊCH VỤ DNS VÀ DHCP
Bài 4: TRIỂN KHAI DỊCH VỤ SAMBA VÀ NFS
Bài 5: TRIỂN KHAI DỊCH VỤ WEB VÀ FTP
Bài 6: TRIỂN KHAI DỊCH VỤ MAIL
Bài 7: BẢO MẬT HỆ THỐNG LINUX
ÔN TẬP
BÁO CÁO ĐỒ ÁN
THI
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Bài 7: BẢO MẬT HỆ THỐNG LINUX
Bảo mật hệ thống mạng bằng Squid Proxy
Bảo mật cho hệ thống Linux bằng Iptables
Bảo mật hệ thống bằng squid proxy và iptables
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
MỤC TIÊU BÀI HỌC
Trình bày được khái niệm và các đặc điểm của hệ thống
proxy.
Giải thích được các thông số cấu hình của squid.
Cấu hình được squid hoạt động ở chế độ cache và
transparent.
Nhận biết hệ thống firewall dùng iptables.
Giải thích các thông số của iptables.
Cấu trúc lệnh của iptables.
Triển khai firewall dùng iptables.
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Tầm quan trọng của cache Proxy
Chia sẻ và cân bằng tải.
Sử dụng lại các object đã được lưu trữ trong cache.
Giảm tải truy xuất trên đường truyền.
Cài đặt, cấu hình squid proxy
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Yêu cầu hệ thống cho cache proxy Server
Tốc độ truy xuất đĩa nhanh
Yêu cầu dung lượng RAM lớn
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Giới thiệu Squid proxy
Squid là chương trình Internet proxy-caching có vai trò tiếp
nhận các yêu cầu từ client và truy vấn đến các Internet
Server thích hợp.
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Giao thức được hỗ trợ trên Squid
Squid hỗ trợ những giao thức sau:
HTTP
FTP
Secure Socket Layer
…
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Cơ chế cache của Squid
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Cài đặt Squid Proxy
Cài đặt squid từ package rpm
Cài đặt từ package squid-version.i386.rpm trong CDROM.
Cài đặt từ lệnh yum: #yum install squid
Cấu trúc thư mục mặc định của Squid
/usr/sbin: Lưu những thư viện của Squid .
/etc/squid: Lưu các tập tin cấu hình squid
(/etc/squid/squid.conf).
/var/log/squid: Lưu các tập tin log của squid
/var/spool/squid: lưu trữ squid cache.
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Cấu hình squid proxy
visible_hostname: Nếu không gán hostname khi đó việc khởi
động squid sẽ thất bại.
visible_hostname bigboy
http_port: cấu hình cổng mà Squid sẽ lắng nghe những yêu cầu
được gởi đến.
http_port 3128
cache_dir: chỉ định nơi cache data được lưu trữ
cache_dir ufs /var/spool/squid 100 16 256
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Cấu hình squid proxy(tt)
Tuỳ chọn Giải thích
cache_dir Định nghĩa những giá trị của thư mục cache được dùng
cho Squid.
ufs Unix file system (ufs) Squid cho biết rằng hệ thống đang
chạy trên Linux
/var/spool/squid Thư mục lưu trữ cache /var/spool/squid.
100 Tổng dung lượng của thư mục cache
16 Số thư mục con được tạo trong thư mục cache
256 Số thư mục con cấp 2 được tạo trong thư mục cache
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Access List
Định nghĩa access list dùng acl Tag:
acl aclname acltype string1 ..
acl aclname acltype "file" ...
Các acl phổ biến:
acl aclname src ip-address/netmask
acl aclname src addr1-addr2/netmask
acl aclname dst ip-address/netmask
acl aclname srcdomain .foo.com
acl aclname dstdomain .foo.com
acl aclname url_regex [-i] ^http://
acl aclname urlpath_regex [-i] \.gif$
acl aclname port 80 70 21
acl aclname port 0-1024
acl aclname proto HTTP FTP ...
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Access List(tt)
acl aclname method GET POST ...
acl aclname time [day] [h1:m1-h2:m2]
day:
S - Sunday
M - Monday
T - Tuesday
W - Wednesday
H - Thursday
F - Friday
A - Saturday
h1:m1 must be less than h2:m2
Ví dụ:
acl home_network src 192.168.1.0/24
acl business_hours time M T W H F 9:00-17:00
http_access allow/deny home_network bussiness_hours
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Access List(tt)
http_access: điều khiển việc truy cập đến Squid
Cú pháp: http_access allow|deny [!]aclname [aclname] ...
icp_port: dùng queries các cache khác
Mặc định: icp_port 8082
cache_peer: chỉ định cache khác theo sự phân cấp
Cú pháp: cache_peer hostname type http_port icp_port
cache_peer proxy2.ispace.edu.vn parent 8080 8082
cache_peer proxy.kcntt.ispace.edu.vn sibling 8080 8082
type :
‘parent’ : proxy cha ở cấp cao hơn
‘sibling’: proxy ngang hàng
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Cấu hình tối thiểu cho squid server
acl all src 0.0.0.0/0.0.0.0
acl manager proto cache_object
acl localhost src 127.0.0.1/255.255.255.255
acl to_localhost dst 127.0.0.0/8
acl SSL_ports port 443 563
acl Safe_ports port 80 # http
acl Safe_ports port 21 # ftp
acl Safe_ports port 443 563 # https, snews
acl Safe_ports port 70 # gopher
acl Safe_ports port 210 # wais
acl Safe_ports port 1025-65535 # unregistered ports
acl Safe_ports port 280 # http-mgmt
acl Safe_ports port 488 # gss-http
acl Safe_ports port 591 # filemaker
acl Safe_ports port 777 # multiling http
acl CONNECT method CONNECT
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Cấu hình tối thiểu cho squid server(tt)
http_access allow manager localhost
http_access deny manager
http_access deny !Safe_ports
http_access deny CONNECT !SSL_ports
# INSERT YOUR OWN RULE(S) HERE TO ALLOW ACCESS FROM
YOUR CLIENTS
For example:
http_access allow home_network business_hours
http_access allow localhost
http_access deny all
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Theo dõi truy xuất internet thông qua Squid
tail –f /var/log/squid/access_log
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Khởi động Squid
Để khởi động Squid ta dùng lệnh sau:
#/etc/init.d/squid start|stop|restart
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Bảo mật Linux
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Log file
Log file: File log để ghi nhận lại các sự kiện, một số file log chính
trong hệ thống
/var/log/messages
/var/log/secure
/var/log/wtmp
/var/log/utmp
Triển khai bảo mật cơ bản trên Linux
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Port Based Security
Cho phép thực thi chức năng lọc gói tin (packet filtering)
thông qua iptables
Triển khai hệ thống firewall trên Linux dùng iptables
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Port Based Security(tt)
Giới thiệu iptables: Iptables do tổ chức Netfilter cung cấp để tăng
tính năng bảo mật trên hệ thống Linux.
Tích hợp tốt với kernel của Linux.
Có khả năng phân tích package hiệu quả.
Lọc package dựa vào MAC và một số cờ hiệu trong TCP header.
Cung cấp kỹ thuật NAT.
…
Cài đặt iptables: iptables được cài đặt mặc định trong hệ thống
Linux.
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Port Based Security(tt)
Cơ chế và chức năng hoạt động của iptables:
Iptables sẽ kiểm tra tất cả các package khi nó đi qua iptables host,
quá trình kiểm tra này được thực hiện một cách tuần tự entry đầu
tiên đến entry cuối cùng.
Có 3 loại bảng trong iptables:
Mangle: chịu trách nhiệm biến đổi quality of service bits trong
TCP header. Thông thường loại table này được ứng dụng trong
SOHO (Small Office/Home Office).
Filter: chịu trách nhiệm thiết lập bộ lọc packet (packet filtering),
có ba loại built-in chains được mô tả để thực hiện các chính sách
về firewall (firewall policy rules).
Forward chain : lọc những gói tin đi qua hệ thống (đi vào
một hệ thống khác).
Input chain: lọc những gói tin đi vào hệ thống.
Output chain : lọc những gói tin đi ra từ hệ thống.
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Port Based Security(tt)
NAT: thực thi chức năng NAT (Network Address
Translation), cung cấp hai loại built-in chains sau:
Pre-routing: sửa địa chỉ đích của gói tin trước khi nó
được routing bởi bảng routing của hệ thống (destination
NAT hay DNAT).
Post-routing: ngược lại với Pre-routing, nó sửa địa chỉ
nguồn của gói tin sau khi gói tin đã được routing bởi hệ
thống (SNAT).
Chú ý: Mỗi rule mà bạn tạo ra phải tương ứng với một chain, table
nào đấy. Nếu bạn không xác định tables nào thì iptables coi mặc
định là cho bảng FILTER.
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Port Based Security(tt)
Sơ đồ sử lý gói tin:
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Port Based Security(tt)
Targets và Jumps:
Target là cơ chế hoạt động trong iptables dùng để nhận diện và
kiểm tra packet.
Jump là cơ chế chuyển một packet đến một target nào đó để xử
lý thêm thao tác khác.
Một số built-in Targets:
ACCEPT: iptables chấp nhận gói tin, đưa nó qua hệ thống mà
không tiếp tục kiểm tra nó nữa.
DROP: iptables loại bỏ gói tin, không tiếp tục xử lý nó nữa.
LOG: thông tin của gói tin sẽ được ghi lại bởi syslog hệ thống,
iptables tiếp tục xử lý gói tin bằng những rules tiếp theo.
REJECT: chức năng của nó cũng giống như DROP tuy nhiên nó
sẽ gửi một error message tới host đã gửi gói tin.
DNAT: dùng để sửa lại địa chỉ đích của gói tin.
SNAT: dùng để sửa lại địa chỉ nguồn của gói tin
MASQUERADE: cũng là một kiểu dùng để sửa địa chỉ nguồn của
gói tin.
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Port Based Security(tt)
Các tuỳ chọn của iptables:
-t : chỉ ra tên của bảng mà rule của bạn sẽ được ghi vào (mặc
định là FILTER ).
-j : nhẩy đến một kiểu xử lý (target) tương ứng như đã định
nghĩa ở trên nếu điều kiện so sánh thoả mãn.
- A : ghi nối tiếp rule vào đuôi một chain
- p : so sánh protocol gói tin.
- s : so sánh địa chỉ nguồn của gói tin.
- d : so sánh địa chỉ đích của gói tin
- i : so sánh tên card mạng mà gói tin đi vào hệ thống.
- o : so sánh tên card mạng mà gói tin từ hệ thống đi ra.
-p tcp --sport : xác định port nguồn của gói tin TCP.
-p tcp --dport : xác định port đích của gói tin TCP
-p udp --sport : xác định port nguồn của gói tin UDP
-p udp --dport : xác định port đích của gói tin UDP
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Port Based Security(tt)
--syn: xác định gói tin có phải là một yêu cầu tạo một kết nối
TCP mới không.
--icmp-type: xác định loại gói icmp (echo-reply hay echo-
request).
-m multiport --sport : xác định các giá trị port
nguồn
-m multiport --dport : xác định các giá trị port
đích.
-m multiport --port : xác định các giá trị port (
không phân biệt nguồn hay đích ).
-m --state : xác định trạng thái kết nối mà gói tin thể
hiện gồm:
ESTABLISHED: gói tin thuộc một kết nối đã được thiết lập.
NEW: gói tin thể hiện một yêu cầu kết nối.
RELATED : gói tin thể hiện một yêu cầu kết nối thứ hai (có liên
quan đến kết nối thứ nhất, thường xuất hiện ở những giao
thức FPT hay ICMP)
INVALID : thể hiện một gói tin không hợp lệ
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Port Based Security(tt)
Cấu trúc lệnh của iptables:
#iptables [-t ]
: Cho phép chọn table khác table mặc định là Filter.
: Xác định hành động sẽ thực hiện, như appending
hoặc deleting rule được chỉ định bởi .
: định nghĩa một cặp thông số xác định điều gì sẽ
xảy ra khi các packet thoả các rule.
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Port Based Security(tt)
Tạo rules firewall
# iptables --append CHAIN selection-criteria --jump
{DROP|ACCEPT|REJECT}
# iptables -A CHAIN selection-criteria -j
{DROP|ACCEPT|REJECT}
Ví dụ:
# iptables -A INPUT -p tcp --dport 25 -j ACCEPT
# iptables -A OUTPUT -p tcp --sport 25 -j ACCEPT
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Port Based Security(tt)
Sử dụng chain tự định nghĩa
Xoá những rule mặc định:
# iptables -F INPUT
# iptables -F OUTPUT
# iptables -F FORWARD
Set default policy (-P or --policy)
# iptables -P INPUT DROP
# iptables -P OUTPUT DROP
# iptables -P FORWARD DROP
Tạo firewall rule
# iptables --append CHAIN selection-criteria --jump
{DROP|ACCEPT|REJECT}
# iptables -A CHAIN selection-criteria -j {DROP|ACCEPT|REJECT}
Mở và đóng một port
# iptables -A INPUT -p tcp --dport 25 -j ACCEPT
# iptables -A OUTPUT -p tcp --sport 25 -j ACCEPT
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Port Based Security(tt)
Dùng địa chỉ IP nguồn và đích
# iptables -A INPUT -s 172.24.0.0/16 -j DROP
# iptables -A OUTPUT -d 172.24.0.0/16 -j DROP
Lọc bởi interface
# iptables -A INPUT -s 192.168.9.0/24 -i eth0 -j DROP
# iptables -A FORWARD -s 192.168.9.0/24 -i eth0 -j DROP
# iptables -A FORWARD -s !192.168.9.0/24 -i eth1 -j DROP
# iptables -A OUTPUT -s !192.168.9.0/24 -i eth1 -j DROP
Trạng thái thực hiện
# iptables -A INPUT -m state -p tcp --dport 80 \
--state NEW,ESTABLISHED,RELATED -j ACCEPT
# iptables -A OUTPUT -m state -p tcp --sport 80 \
--state ESTABLISHED,RELATED -j ACCEPT
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Port Based Security(tt)
Để lưu giữ cấu hình iptables vào trong file
/etc/sysconfig/iptables ta dùng lệnh sau:
#service iptables save
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Port Based Security(tt)
Load kernel module cần cho iptables
Module ip_conntrack
Module ip_conntrack_ftp
Module iptable_nat
Module ip_nat_ftp
Có thể mô tả trong file /etc/rc.local
Modprobe ip_conntrack
Modprobe ip_conntrack_ftp
Modprobe iptable_nat
Modprobe ip_nat_ftp
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Port Based Security(tt)
Bảo vệ HDH:
Thay đổi trong file /etc/sysctl.conf
Net/ipv4/conf/all/rp_filter = 1
Net/ipv4/conf/all/log_martians = 1
Net/ipv4/conf/all/send_redirects = 0
Net/ipv4/conf/all/accept_source_route = 0
Net/ipv4/conf/all/accept_redirects = 0
Net/ipv4/tcp_syncookies = 1
Net/ipv4/icmp_echo_ignore_broadcasts = 1
Net/ipv4/ip_forward = 1
Sau đó dùng “sysctl -p” để cập nhật lại
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Port Based Security(tt)
Khắc phục sự cố trên iptables:
Firewall logs được ghi nhận vào file /var/log/message
Để cho phép iptables ghi log vào file /var/log/message ta định
nghĩa chain cho iptables như sau:
iptables -A OUTPUT -j LOG
iptables -A INPUT -j LOG
iptables -A FORWARD -j LOG
iptables -A OUTPUT -j DROP
iptables -A INPUT -j DROP
iptables -A FORWARD -j DROP
Chú ý: Khi ta thay đổi cấu hình trên iptables thì ta dùng lệnh
#service iptables save để save lại thay đổi và khởi động lại iptables
#service iptables restart
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
Câu hỏi ôn tập
Trình bày các đặc điểm chính của squid proxy.
Giải thích các thông số cấu hình squid proxy.
Phân biệt cơ chế cache và transparent
Triển khai và cấu hình dịch vụ proxy.
Giải thích các thông số cấu hình iptables.
Các bước triển khai và cấu hình iptables.
Viết các rule cho các dịch vụ thông dụng: www,ftp,smtp,…
TRƯỜNG TRUNG CẤP VIỆT KHOA Website:
HỎI - ĐÁP