squid:setup_squid
Differences
This shows you the differences between two versions of the page.
Next revision | Previous revision | ||
squid:setup_squid [2021/01/06 11:35] – created peter | squid:setup_squid [2021/01/06 11:44] (current) – removed peter | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | ====== Squid - Setup Squid ====== | ||
- | |||
- | < | ||
- | apt-get update && apt-get upgrade -y | ||
- | |||
- | apt-get install devscripts \ | ||
- | build-essential \ | ||
- | openssl libssl-dev \ | ||
- | fakeroot \ | ||
- | libcppunit-dev \ | ||
- | libsasl2-dev \ | ||
- | cdbs \ | ||
- | ccze \ | ||
- | libfile-readbackwards-perl \ | ||
- | libcap2 \ | ||
- | libcap-dev \ | ||
- | libcap2-dev \ | ||
- | libtool \ | ||
- | sysv-rc-conf -y && | ||
- | wget http:// | ||
- | tar -xjf squid-3.5.3.tar.bz2 && | ||
- | cd squid-3.5.3 && | ||
- | ./configure \ | ||
- | --prefix=/ | ||
- | --includedir=/ | ||
- | --infodir=/ | ||
- | --sysconfdir=/ | ||
- | --localstatedir=/ | ||
- | --libexecdir=/ | ||
- | --srcdir=. \ | ||
- | --datadir=/ | ||
- | --sysconfdir=/ | ||
- | --mandir=/ | ||
- | --enable-inline \ | ||
- | --enable-async-io=24 \ | ||
- | --enable-storeio=ufs, | ||
- | --enable-removal-policies=lru, | ||
- | --enable-gnuregex \ | ||
- | --enable-delay-pools \ | ||
- | --enable-cache-digests \ | ||
- | --enable-underscores \ | ||
- | --enable-icap-client \ | ||
- | --enable-follow-x-forwarded-for \ | ||
- | --enable-eui \ | ||
- | --enable-esi \ | ||
- | --enable-icmp \ | ||
- | --enable-zph-qos \ | ||
- | --enable-http-violations \ | ||
- | --enable-ssl-crtd \ | ||
- | --enable-linux-netfilter \ | ||
- | --enable-ltdl-install \ | ||
- | --enable-ltdl-convenience \ | ||
- | --enable-x-accelerator-vary \ | ||
- | --disable-maintainer-mode \ | ||
- | --disable-dependency-tracking \ | ||
- | --disable-silent-rules \ | ||
- | --disable-translation \ | ||
- | --disable-ipv6 \ | ||
- | --disable-ident-lookups \ | ||
- | --with-swapdir=/ | ||
- | --with-logdir=/ | ||
- | --with-pidfile=/ | ||
- | --with-aufs-threads=24 \ | ||
- | --with-filedescriptors=65536 \ | ||
- | --with-large-files \ | ||
- | --with-maxfd=65536 \ | ||
- | --with-openssl \ | ||
- | --with-default-user=proxy \ | ||
- | --with-included-ltdl && | ||
- | make && make install | ||
- | |||
- | |||
- | mkdir / | ||
- | chown -R nobody / | ||
- | / | ||
- | chown -R proxy:proxy / | ||
- | chmod -R 777 / | ||
- | |||
- | nano / | ||
- | |||
- | # | ||
- | # Recommended minimum configuration: | ||
- | # | ||
- | |||
- | # Example rule allowing access from your local networks. | ||
- | # Adapt to list your (internal) IP networks from where browsing | ||
- | # should be allowed | ||
- | acl localnet src 192.168.10.0/ | ||
- | acl localnet src 10.10.10.0/ | ||
- | acl localnet src 10.10.20.0/ | ||
- | acl localnet src 10.10.30.0/ | ||
- | |||
- | acl SSL_ports port 443 | ||
- | acl Safe_ports port 80 # http | ||
- | acl Safe_ports port 21 # ftp | ||
- | acl Safe_ports port 443 # https | ||
- | 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 | ||
- | |||
- | # TAG: QUERY | ||
- | # ----------------------------------------------------------------------------- | ||
- | acl QUERY urlpath_regex -i (hackshield|blank.html|infinity.js|hshield.da|renew_session_token.php|recaptcha.js|dat.asp|notice.swf|patchlist.txt|hackshield|captcha|reset.css|update.ver|notice.html|updates.txt|gamenotice|images.kom|patchinfo.xml|noupdate.ui|\.Xtp|\.htc|\.txt) | ||
- | acl QUERY urlpath_regex -i (patch.conf|uiimageset.xml.iop|gashaponwnd.xml.iop|loading.swf|download.swf|version.list|version.ini|launch.jnlp|server_patch.cfg.iop|core.swf|Loading.swf|resouececheck.sq|mainloading.swf|config.xml|gemmaze.swf|xml.png|size.xml|resourcesbar.swf|version.xml|version.list|delete.ini) | ||
- | acl QUERY urlpath_regex -i \.(jsp|asp|aspx|cfg|iop|zip|php|xml|html)(\? | ||
- | cache deny QUERY | ||
- | |||
- | # | ||
- | acl dontstore url_regex ^http: | ||
- | acl dontstore url_regex redbot\.org \.php | ||
- | acl dontstore url_regex -i ^http: | ||
- | acl dontstore url_regex \.(aspx|php)\? | ||
- | acl dontstore url_regex goldprice\.org\/ | ||
- | acl dontstore url_regex google\.co(m|\.[a-z]{2})\/ | ||
- | acl dontstore url_regex redirector\.([0-9.]{4}|.*\.youtube\.com|.*\.googlevideo\.com|.*\.video\.google\.com)\/ | ||
- | |||
- | acl store_yt_id url_regex -i youtube.*(ptracking|stream_204|playback|player_204|watchtime|set_awesome|s\? | ||
- | acl store_id_list_yt url_regex -i (youtube|googlevideo).*videoplayback.*$ | ||
- | acl store_id_list_yt url_regex ^https? | ||
- | |||
- | acl store-id_list urlpath_regex -i dl\.sourceforge\.net | ||
- | acl store-id_list urlpath_regex -i \.ytimg\.com | ||
- | acl store-id_list urlpath_regex -i \.(akamaihd|fbcdn)\.net | ||
- | acl store_id_list urlpath_regex -i [a-zA-Z]{2}[0-9]*\.4shared\.com\/ | ||
- | |||
- | acl store_id_list_url url_regex ^http: | ||
- | acl store_id_list_url url_regex ^http[s]?: | ||
- | acl store_id_list_url url_regex ^http[s]?: | ||
- | acl store_id_list_url url_regex ^https: | ||
- | acl store_id_list_url url_regex ^http: | ||
- | |||
- | request_header_access Range deny store_id_list_yt | ||
- | range_offset_limit 10 KB store_id_list_yt | ||
- | |||
- | acl loop_302 http_status 302 | ||
- | acl getmethod method GET | ||
- | |||
- | ############################################################################### | ||
- | # Recommended minimum Access Permission configuration: | ||
- | # | ||
- | # Deny requests to certain unsafe ports | ||
- | ############################################################################### | ||
- | http_access deny !Safe_ports | ||
- | http_access deny CONNECT !SSL_ports | ||
- | http_access allow localhost manager | ||
- | http_access deny manager | ||
- | http_access allow localnet | ||
- | http_access allow localhost | ||
- | http_access deny all | ||
- | |||
- | ############################################################################### | ||
- | # squid ssl_bump option | ||
- | ############################################################################### | ||
- | always_direct allow all | ||
- | ssl_bump server-first all | ||
- | sslproxy_cert_error deny all | ||
- | sslproxy_flags DONT_VERIFY_PEER | ||
- | |||
- | sslcrtd_program / | ||
- | sslcrtd_children 8 startup=1 idle=1 | ||
- | |||
- | ############################################################################### | ||
- | # Squid normally listens to port 3128 | ||
- | ############################################################################### | ||
- | https_port 3130 tproxy ssl-bump generate-host-certificates=on dynamic_cert_mem_cache_size=4MB cert=/ | ||
- | http_port 3129 tproxy | ||
- | http_port 3128 | ||
- | |||
- | # TAG: Store-id Program | ||
- | # ----------------------------------------------------------------------------- | ||
- | store_id_program / | ||
- | store_id_children 100 startup=0 idle=1 concurrency=1000 | ||
- | |||
- | # TAG: Store-id Access | ||
- | # ----------------------------------------------------------------------------- | ||
- | store_id_access deny dontstore | ||
- | store_id_access deny !getmethod | ||
- | store_id_access allow store_id_list_yt | ||
- | store_id_access allow store_yt_id | ||
- | store_id_access allow store-id_list | ||
- | store_id_access deny all | ||
- | store_id_bypass on | ||
- | |||
- | # TAG: Youtube 302 | ||
- | # ----------------------------------------------------------------------------- | ||
- | store_miss deny store_id_list_yt loop_302 | ||
- | send_hit deny store_id_list_yt loop_302 | ||
- | |||
- | ############################################################################### | ||
- | ## MEMORY CACHE OPTIONS | ||
- | ############################################################################### | ||
- | client_dst_passthru on | ||
- | cache_mem 1024 MB | ||
- | maximum_object_size_in_memory 1024 KB | ||
- | memory_cache_shared off | ||
- | memory_cache_mode disk | ||
- | memory_replacement_policy heap GDSF | ||
- | |||
- | ############################################################################### | ||
- | ## DISK CACHE OPTIONS | ||
- | ############################################################################### | ||
- | cache_replacement_policy heap LFUDA | ||
- | minimum_object_size 1 bytes | ||
- | maximum_object_size 10 GB | ||
- | |||
- | ############################################################################### | ||
- | # Uncomment and adjust the following to add a disk cache directory. | ||
- | ############################################################################### | ||
- | cache_dir aufs /cache-1 500000 16 256 # sesuaikan dengan drive penyimpanan cache | ||
- | cache_dir aufs /cache-2 500000 16 256 # sesuaikan dengan drive penyimpanan cache | ||
- | store_dir_select_algorithm round-robin | ||
- | cache_swap_low 90 | ||
- | cache_swap_high 95 | ||
- | |||
- | ############################################################################### | ||
- | # Leave coredumps in the first cache dir | ||
- | ############################################################################### | ||
- | coredump_dir / | ||
- | |||
- | ############################################################################### | ||
- | ## LOGFILE OPTIONS | ||
- | ############################################################################### | ||
- | #access_log daemon:/ | ||
- | access_log / | ||
- | logfile_daemon / | ||
- | cache_store_log none | ||
- | logfile_rotate 1 | ||
- | mime_table / | ||
- | pid_filename / | ||
- | strip_query_terms off | ||
- | buffered_logs off | ||
- | |||
- | ############################################################################### | ||
- | ## OPTIONS FOR TROUBLESHOOTING | ||
- | ############################################################################### | ||
- | #cache_log / | ||
- | cache_log /dev/null | ||
- | # | ||
- | coredump_dir / | ||
- | |||
- | ############################################################################### | ||
- | ## OPTIONS FOR TUNING THE CACHE | ||
- | ############################################################################### | ||
- | max_stale 1 years | ||
- | vary_ignore_expire on | ||
- | shutdown_lifetime 10 seconds | ||
- | |||
- | ############################################################################### | ||
- | # Add any of your own refresh_pattern entries above these. | ||
- | ############################################################################### | ||
- | refresh_pattern ^ftp: 1440 20% 10080 | ||
- | refresh_pattern ^gopher: 1440 0% 1440 | ||
- | refresh_pattern -i (/ | ||
- | |||
- | # Youtube Video. | ||
- | refresh_pattern -i (get_video\? | ||
- | refresh_pattern -i ^https? | ||
- | refresh_pattern -i ^https? | ||
- | |||
- | # Youtube images. | ||
- | refresh_pattern -i (yimg|twimg)\.com\.* | ||
- | refresh_pattern -i (ytimg|ggpht)\.com\.* | ||
- | |||
- | # Facebook Images. | ||
- | refresh_pattern -i fbcdn.*net\/ | ||
- | refresh_pattern -i pixel\.facebook\.com.*\.(jpg|png|gif|ico|css|js) 241920 80% 241920 override-expire ignore-reload reload-into-ims ignore-auth | ||
- | refresh_pattern -i \.akamaihd\.net.*\.(jpg|png|gif|ico|css|js) 241920 80% 241920 override-expire ignore-reload reload-into-ims ignore-auth | ||
- | refresh_pattern -i ((facebook.com)|(85.131.151.39))\.(jpg|png|gif) 241920 99% 241920 ignore-reload override-expire ignore-no-store store-stale | ||
- | refresh_pattern -i fbcdn\.net\/ | ||
- | refresh_pattern static\.(xx|ak)\.fbcdn\.net*\.(jpg|gif|png) 241920 99% 241920 ignore-reload override-expire ignore-no-store | ||
- | refresh_pattern ^https? | ||
- | |||
- | # Facebook Video. | ||
- | refresh_pattern -i \.video.ak.fbcdn.net.*\.(mp4|flv|mp3|amf) | ||
- | refresh_pattern (audio|video)\/ | ||
- | refresh_pattern -i ^http:// | ||
- | |||
- | # All Files. | ||
- | refresh_pattern -i \.(3gp|7z|ace|asx|bin|deb|divx|dvr-ms|ram|rpm|exe|inc|cab|qt) 10080 80% 10080 override-expire override-lastmod reload-into-ims | ||
- | refresh_pattern -i \.(rar|jar|gz|tgz|bz2|iso|m1v|m2(v|p)|mo(d|v)|arj|lha|lzh|zip|tar|iop|nzp|pak|mar|msp) 10080 80% 10080 override-expire override-lastmod reload-into-ims ignore-reload | ||
- | refresh_pattern -i \.(jp(e? | ||
- | refresh_pattern -i \.(avi|ac4|mp(e? | ||
- | refresh_pattern -i \.(pp(t? | ||
- | refresh_pattern . 0 20% 4320 | ||
- | |||
- | ############################################################################### | ||
- | ## ADMINISTRATIVE PARAMETERS | ||
- | ############################################################################### | ||
- | cache_mgr eko.hendratno@gmail.com | ||
- | cache_effective_user proxy | ||
- | cache_effective_group proxy | ||
- | visible_hostname gtw.home.lan | ||
- | unique_hostname gtw.home.lan | ||
- | |||
- | ############################################################################### | ||
- | ## PERSISTENT CONNECTION HANDLING | ||
- | ############################################################################### | ||
- | detect_broken_pconn on | ||
- | client_persistent_connections off | ||
- | server_persistent_connections on | ||
- | |||
- | ############################################################################### | ||
- | ## ERROR PAGE OPTIONS | ||
- | ############################################################################### | ||
- | error_directory / | ||
- | error_log_languages off | ||
- | |||
- | ############################################################################### | ||
- | ## DNS OPTIONS | ||
- | ############################################################################### | ||
- | check_hostnames off | ||
- | hosts_file /etc/hosts | ||
- | connect_retries 2 | ||
- | ipcache_low 90 | ||
- | ipcache_high 95 | ||
- | ipcache_size 10024 # 2x Besar RAM | ||
- | fqdncache_size 7024 # real RAM Hardware | ||
- | pipeline_prefetch 100 | ||
- | |||
- | ############################################################################### | ||
- | ## MISCELLANEOUS | ||
- | ############################################################################### | ||
- | memory_pools off | ||
- | reload_into_ims on | ||
- | uri_whitespace strip | ||
- | max_filedescriptors 65536 | ||
- | |||
- | |||
- | |||
- | ================================= | ||
- | nano /etc/squid / | ||
- | ================================= | ||
- | # | ||
- | ########################### | ||
- | # | ||
- | # Store-ID dengan asumsi chanel berapapun | ||
- | # | ||
- | ########################### | ||
- | $|=1; | ||
- | while (<>) { | ||
- | my $chan = ""; | ||
- | if (s/ | ||
- | $chan = $1; | ||
- | } | ||
- | $_ =~ s/ | ||
- | |||
- | if ($_ =~ m/ | ||
- | $vid = $3 ; | ||
- | @cpn = m/ | ||
- | $fn = "/ | ||
- | unless (-e $fn) { | ||
- | open FH,">" | ||
- | print FH " | ||
- | close FH; | ||
- | } | ||
- | print $chan, " | ||
- | |||
- | } elsif ($_ =~ m/ | ||
- | @itag = m/ | ||
- | @ids = m/ | ||
- | @mime = m/ | ||
- | @cpn = m/ | ||
- | @range = m/ | ||
- | if (defined($cpn[0])) { | ||
- | $fn = "/ | ||
- | if (-e $fn) { | ||
- | open FH,"<" | ||
- | $id = <fh>; | ||
- | chomp $id ; | ||
- | close FH ; | ||
- | } else { | ||
- | $id = $ids[0] ; | ||
- | } | ||
- | print $chan, "OK store-id=http:// | ||
- | } else { | ||
- | print $chan, " | ||
- | } | ||
- | |||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | |||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | |||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=storeurl:// | ||
- | |||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | |||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | |||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | |||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } elsif ($_ =~ m/ | ||
- | print $chan, "OK store-id=http:// | ||
- | } else { | ||
- | print $chan, " | ||
- | } | ||
- | } | ||
- | ================================= | ||
- | nano / | ||
- | ================================= | ||
- | #! /bin/sh | ||
- | # | ||
- | # squid Startup script for the SQUID HTTP proxy-cache. | ||
- | # | ||
- | # Version: | ||
- | # | ||
- | ### BEGIN INIT INFO | ||
- | # Provides: | ||
- | # Required-Start: | ||
- | # Required-Stop: | ||
- | # Should-Start: | ||
- | # Should-Stop: | ||
- | # Default-Start: | ||
- | # Default-Stop: | ||
- | # Short-Description: | ||
- | ### END INIT INFO | ||
- | |||
- | NAME=squid | ||
- | DAEMON=/ | ||
- | LIB=/ | ||
- | PIDFILE=/ | ||
- | # export LD_PRELOAD=/ | ||
- | SQUID_ARGS=" | ||
- | |||
- | [ ! -f / | ||
- | |||
- | . / | ||
- | |||
- | PATH=/ | ||
- | |||
- | [ -x $DAEMON ] || exit 0 | ||
- | |||
- | grepconf () { | ||
- | w=" | ||
- | sq=/ | ||
- | # sed is cool. | ||
- | res=`sed -ne ' | ||
- | s/ | ||
- | t end; | ||
- | d; | ||
- | :end q' < $sq` | ||
- | [ -n " | ||
- | echo " | ||
- | } | ||
- | |||
- | grepconf2 () { | ||
- | w=" | ||
- | sq=/ | ||
- | # sed is cool. | ||
- | res=`sed -ne ' | ||
- | s/ | ||
- | t end; | ||
- | d; | ||
- | :end q' < $sq` | ||
- | [ -n " | ||
- | echo " | ||
- | } | ||
- | |||
- | # | ||
- | # Try to increase the # of filedescriptors we can open. | ||
- | # | ||
- | maxfds () { | ||
- | [ -n " | ||
- | [ -f / | ||
- | global_file_max=`cat / | ||
- | minimal_file_max=$(($SQUID_MAXFD + 4096)) | ||
- | if [ " | ||
- | then | ||
- | echo $minimal_file_max > / | ||
- | fi | ||
- | ulimit -n $SQUID_MAXFD | ||
- | } | ||
- | |||
- | start () { | ||
- | cdr=`grepconf2 cache_dir /cache-1` | ||
- | ctp=`grepconf cache_dir ufs` | ||
- | |||
- | case " | ||
- | [0-9]*) | ||
- | log_failure_msg " | ||
- | log_end_msg 1 | ||
- | exit 1 | ||
- | ;; | ||
- | esac | ||
- | | ||
- | # | ||
- | # Create spool dirs if they don't exist. | ||
- | # | ||
- | if [ -d " | ||
- | then | ||
- | log_warning_msg " | ||
- | $DAEMON $SQUID_ARGS -z | ||
- | fi | ||
- | |||
- | if [ " | ||
- | CHUID=root | ||
- | fi | ||
- | |||
- | maxfds | ||
- | umask 027 | ||
- | start-stop-daemon --quiet --start \ | ||
- | --pidfile $PIDFILE \ | ||
- | --chuid $CHUID \ | ||
- | --exec $DAEMON -- $SQUID_ARGS < /dev/null | ||
- | return $? | ||
- | } | ||
- | |||
- | stop () { | ||
- | PID=`cat $PIDFILE 2>/ | ||
- | start-stop-daemon --stop --quiet --pidfile $PIDFILE --name squid | ||
- | # | ||
- | # Now we have to wait until squid has _really_ stopped. | ||
- | # | ||
- | sleep 2 | ||
- | if test -n " | ||
- | then | ||
- | log_action_begin_msg " Waiting" | ||
- | cnt=0 | ||
- | while kill -0 $PID 2>/ | ||
- | do | ||
- | cnt=`expr $cnt + 1` | ||
- | if [ $cnt -gt 24 ] | ||
- | then | ||
- | log_action_end_msg 1 | ||
- | return 1 | ||
- | fi | ||
- | sleep 5 | ||
- | log_action_cont_msg "" | ||
- | done | ||
- | log_action_end_msg 0 | ||
- | return 0 | ||
- | else | ||
- | return 0 | ||
- | fi | ||
- | } | ||
- | |||
- | case " | ||
- | start) | ||
- | log_daemon_msg " | ||
- | if start ; then | ||
- | log_end_msg $? | ||
- | else | ||
- | log_end_msg $? | ||
- | fi | ||
- | ;; | ||
- | stop) | ||
- | log_daemon_msg " | ||
- | if stop ; then | ||
- | log_end_msg $? | ||
- | else | ||
- | log_end_msg $? | ||
- | fi | ||
- | ;; | ||
- | reload|force-reload) | ||
- | log_action_msg " | ||
- | $DAEMON -k reconfigure | ||
- | log_action_end_msg 0 | ||
- | ;; | ||
- | restart) | ||
- | log_daemon_msg " | ||
- | stop | ||
- | if start ; then | ||
- | log_end_msg $? | ||
- | else | ||
- | log_end_msg $? | ||
- | fi | ||
- | ;; | ||
- | status) | ||
- | status_of_proc -p " | ||
- | ;; | ||
- | *) | ||
- | echo " | ||
- | exit 3 | ||
- | ;; | ||
- | esac | ||
- | |||
- | exit 0 | ||
- | |||
- | |||
- | ================================= | ||
- | chmod +x store-id.pl | ||
- | chmod +x squid | ||
- | chown proxy:proxy /cache-1 | ||
- | chown proxy:proxy /cache-2 && | ||
- | chmod 777 /cache-1 && | ||
- | chmod 777 /cache-2 | ||
- | squid -f / | ||
- | |||
- | sysv-rc-conf squid default | ||
- | |||
- | ================================= | ||
- | nano / | ||
- | ================================= | ||
- | #0 | ||
- | iptables -A POSTROUTING -t nat -j MASQUERADE -o eth0 | ||
- | #1 | ||
- | iptables -t mangle -F | ||
- | iptables -t mangle -X | ||
- | #2 | ||
- | echo 0 > / | ||
- | echo 1 > / | ||
- | #3 | ||
- | ip rule add fwmark 1 lookup 100 | ||
- | ip route add local 0.0.0.0/0 dev lo table 100 | ||
- | #4 | ||
- | iptables -t mangle -N DIVERT | ||
- | iptables -t mangle -A PREROUTING -p tcp -m socket -j DIVERT | ||
- | #5 | ||
- | iptables -t mangle -A DIVERT -j MARK --set-mark 1 | ||
- | iptables -t mangle -A DIVERT -j ACCEPT | ||
- | #6 | ||
- | iptables -t mangle -A PREROUTING -p tcp --dport 80 -j TPROXY --tproxy-mark 0x1/0x1 --on-port 3129 | ||
- | iptables -t mangle -A PREROUTING -p tcp --dport 443 -j TPROXY --tproxy-mark 0x1/0x1 --on-port 3130 | ||
- | #7 | ||
- | squid start | ||
- | exit 0 | ||
- | =================================================================================================== | ||
- | squid -k parse | ||
- | squid -k reconfigure | ||
- | squid -z | ||
- | squid start | ||
- | |||
- | tail -f / | ||
- | </ | ||
squid/setup_squid.1609932907.txt.gz · Last modified: 2021/01/06 11:35 by peter