2024年11月Centos如何通过nginx反向代理和proxy_cache缓存搭建CDN服务器(2)

发布时间:

  ⑴、添加Nginx启动文件

  ⑵这个文件内容和参考文章里的启动文件内容有些不一样 ,参考文章里的启动文件在我的Nginx服务器里报语法错误。

  ⑶vi /etc/rc.d/init.d/nginx #编辑启动文件#!/bin/bash# nginx Startup script for the Nginx HTTP Server# it is v... version.# chkconfig: - # description: Nginx is a high-performance web and proxy server.# It has a lot of features, but it's not for everyone.# processname: nginx# pidfile: /var/run/nginx.pid# config: /usr/local/nginx/conf/nginx.confnginxd=/usr/local/nginx/sbin/nginxnginx_config=/usr/local/nginx/conf/nginx.confnginx_pid=/usr/local/nginx/logs/nginx.pidRETVAL=prog="nginx"# Source function library.. /etc/rc.d/init.d/functions# Source working configuration.. /etc/sysconfig/work# Check that working is up.[ ${WORKING} = "no" ] && exit [ -x $nginxd ] || exit # Start nginx daemons functions.start() {if [ -e $nginx_pid ];then echo "nginx already running...." exit fi echo -n $"Starting $prog: " daemon $nginxd -c ${nginx_config} RETVAL=$? echo [ $RETVAL = ] && touch /var/lock/subsys/nginx return $RETVAL}# Stop nginx daemons functions.stop() {echo -n $"Stopping $prog: "killproc $nginxdRETVAL=$?echo[ $RETVAL = ] && rm -f /var/lock/subsys/nginx /usr/local/nginx/logs/nginx.pid}# reload nginx service functions.reload() { echo -n $"Reloading $prog: " #kill -HUP `cat ${nginx_pid}` killproc $nginxd -HUP RETVAL=$? echo}# See how we were called.case "$" instart) start ;;stop) stop ;;reload) reload ;;restart) stop start ;;status) status $prog RETVAL=$? ;;*) echo $"Usage: $prog {start|stop|restart|reload|status|help}" exit esacexit $RETVAL:wq #保存退出chmod /etc/rc.d/init.d/nginx #赋予文件执行权限chkconfig nginx on #设置开机启动/etc/rc.d/init.d/nginx restartservice nginx restart

  ⑷、配置Nginx

  ⑸cp /usr/local/nginx/conf/nginx.conf /usr/local/nginx/conf/nginx.confbak #备份nginx配置文件

  ⑹vi /usr/local/nginx/conf/nginx.conf

  ⑺(一)、设置nginx运行账号

  ⑻找到user nobody;修改为 user www www; #在第一行

  ⑼(二)、禁止nginx空主机头,找到server,在上面一行添加如下内容:

  ⑽server { listen default; server_name _; location / { root html; return ; } location ~ /.ht { deny all; }}/etc/rc.d/init.d/nginx restart #重启nginx 这样设置之后,空主机头访问会直接跳转到nginx错误页面。

  ⑾(三)、添加nginx虚拟主机包含文件

  ⑿cd /usr/local/nginx/conf/ #进入nginx安装目录mkdir vhost #建立虚拟目录vi /usr/local/nginx/conf/nginx.conf #编辑 找到上一步添加的代码,在最后添加:include vhost/*.conf;例如:server { listen default; server_name _; location / { root html; return ; } location ~ /.ht { deny all; }}include vhost/*.conf;

  ⒀(四)、添加proxy_cache参数配置包含文件

  ⒁cd /usr/local/nginx/conf/ touch proxy.conf vi /usr/local/nginx/conf/nginx.conf #编辑 找到http { 在下面添加一行include proxy.conf;

  ⒂(五)、添加被代理服务器列表包含文件

  ⒃cd /usr/local/nginx/conf/ touch mysvrhost.conf vi /usr/local/nginx/conf/nginx.conf #编辑 找到上一步添加的代码,在下面添加一行include mysvrhost.conf;

  ⒄(六)、设置nginx全局参数

  ⒅vi /usr/local/nginx/conf/nginx.conf worker_processes ; #工作进程数,为CPU的核心数或者两倍events{ use epoll; #增加 worker_connections ; #修改为,最大连接数。}以下代码在http { 部分增加与修改server_names_hash_bucket_size ; #增加client_header_buffer_size k; #增加large_client_header_buffers k; #增加client_max_body_size m; #增加tcp_nopush on; #修改为onkeepalive_timeout ; #修改为tcp_nodelay on; #增加server_tokens off; #增加,不显示nginx版本信息gzip on; #修改为ongzip_min_length k; #增加gzip_buffers k; #增加gzip_http_version .; #增加gzip_p_level ; #增加gzip_types text/plain application/x-javascript text/css application/xml; #增加gzip_vary on; #增加

  ⒆(七)、设置proxy_cache参数配置

  ⒇cd /home mkdir -p /home/proxy_temp_dir #proxy_temp_dir与proxy_cache_dir这两个文件夹必须在同一个分区mkdir -p /home/proxy_cache_dir #proxy_cache_dir与proxy_temp_dir这两个文件夹必须在同一个分区chown -R proxy_cache_dir proxy_temp_dir #设置目录所有者chmod -R proxy_cache_dir proxy_temp_dir #设置目录权限cd /usr/local/nginx/conf/ vi proxy.conf #编辑,添加以下代码proxy_temp_path /home/proxy_temp_dir; #指定临时文件目录proxy_cache_path /home/proxy_cache_dir levels=: keys_zone=cache_one:m inactive=dmax_size=g; #设置Web缓存区名称为cache_one,内存缓存为MB,自动清除天内没有被访问的文件,硬盘缓存为GB。client_body_buffer_size k; #增加缓冲区代理缓冲客户端请求的最大字节数proxy_connect_timeout ; #增加连接后端服务器超时时间proxy_read_timeout ; #增加后端服务器响应请求超时时间proxy_send_timeout ; #增加后端服务器发送数据超时时间proxy_buffer_size k; #增加代理请求缓存区大小proxy_buffers k; #增加proxy_busy_buffers_size k; #增加系统繁忙时可申请的proxy_buffers大小proxy_temp_file_write_size k; #增加proxy缓存临时文件的大小proxy_next_upstream error timeout invalid_header http_ http_ http_; #增加故障转移,如果后端的服务器返回、、执行超时等错误,自动将请求转发到upstream负载均衡池中的另一台服务器,实现故障转移。proxy_cache cache_one; #增加使用web缓存区cache_one