分类
IT运维

nginx安装

1、下载所需文件到源码目录

cd /usr/local/src

2、下载nginx-1.12.2.tar.gz

wget http://nginx.org/download/nginx-1.12.2.tar.gz
tar -xzvf nginx-1.12.2.tar.gz

3、下载openssl-1.1.0g.tar.gz

wget http://www.geekapp.cn/download/openssl-1.1.0g.tar.gz
tar -xzvf openssl-1.1.0g.tar.gz

4、下载pcre-8.21.tar.gz

wget http://www.geekapp.cn/download/pcre-8.21.tar.gz
tar -xzvf pcre-8.21.tar.gz

5、下载zlib-1.2.8.tar.gz

wget http://www.geekapp.cn/download/zlib-1.2.8.tar.gz
tar -xzvf zlib-1.2.8.tar.gz

6、安装nginx

cd nginx-1.12.2
./configure --sbin-path=/usr/local/nginx/nginx \
--conf-path=/usr/local/nginx/nginx.conf \
--pid-path=/usr/local/nginx/nginx.pid \
--with-http_ssl_module \
--with-pcre=/usr/local/src/pcre-8.21 \
--with-zlib=/usr/local/src/zlib-1.2.8 \
--with-openssl=/usr/local/src/openssl-1.1.0g
make
make install
分类
IT运维

videojs处理m3u8不能播放问题

videojs处理m3u8视频文件,提示已拦截跨源请求:同源策略禁止读取位于XXX的远程资源。(原因:CORS 头缺少 ‘Access-Control-Allow-Origin’)
服务端处理用的是nginx,解决方法:

location /hls {
add_header Access-Control-Allow-Origin *;#关键配置
types{
application/x-mpegURL m3u8;#关键配置
video/mp2t ts;#关键配置
}
alias temp/hls;
expires -1;
add_header Cache-Control no-cache;
}

分类
IT运维

配置nginx代理tomcat

配置nginx代理tomcat,配置如下:
upstream tomcat {
server 127.0.0.1:8080;
}

server {
listen 80;
server_name test.geekapp.cn;
location / {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header REMOTE-HOST $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
#以上4句是可以使客户端真实ip,否则被代理服务获取的IP是127.0.0.1
proxy_pass http://tomcat;
}

}

分类
IT运维

nginx图片防止盗链的配置

nginx模块ngx_http_referer_module通常用于阻挡来源非法的域名请求。但是伪装Referer头部是非常简单的事情,所以这个模块只能用于阻止大部分非法请求。

location ~* \.(gif|jpg|png|jpeg)$ {
    valid_referers none blocked *.geekapp.cn server_names ~\.google\. ~\.baidu\. ~\.haosou\. ~\.sogou\. ~\.bing\.;
    if ($invalid_referer) {
        return 403;
        #rewrite ^/ http://www.geekapp.cn/403.jpg;
    }
    expires 30d;
}

原创内容转载请保留出处GEEK笔记(http://www.geekapp.cn/)。

分类
IT运维

配置Nginx代理jsp页面

本例nginx监听80端口,jsp容器为tomcat并监听8080端口。配置的目的是使静态页面、文件等直接由nginx处理,jsp动态页面由tomcat处理。这样的分工处理,发挥nginx处理静态页面高并发的优势,以达到提高处理效率的目的。
1、修改nginx配置nginx.conf

vi nginx.conf

2、在相应server下面添加如下location语法

#配置代理jsp页面
location ~ \.jsp$ {
	proxy_pass http://127.0.0.1:8080/$request_uri;
	proxy_redirect off;
	proxy_set_header HOST $host;
	proxy_set_header X-Real-IP $remote_addr;
	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
	client_max_body_size 10m;
	client_body_buffer_size 128k;
	proxy_connect_timeout 90;
	proxy_send_timeout 90;
	proxy_read_timeout 90;
	proxy_buffer_size 4k;
	proxy_buffers 4 32k;
	proxy_busy_buffers_size 64k;
	proxy_temp_file_write_size 64k;
}
#屏蔽掉相关目录访问权限
location ^~ /WEB-INF/{
	deny all;
}

3、加载配置使生效

nginx -s reload

原创内容转载请保留出处GEEK笔记(http://www.geekapp.cn/)。

分类
WEB开发

Nginx与PHP(FastCGI)配置wordpress站点

FastCGI是一个可伸缩地、高速地在HTTP server和动态脚本语言间通信的接口。多数流行的HTTP server都支持FastCGI,包括Apache、Nginx和lighttpd等,同时,FastCGI也被许多脚本语言所支持,其中就有PHP。

vi nginx.conf

完整的server配置如下:

server {
    listen       80;
    server_name  www.htmlgames.cn htmlgames.cn www.youxitequ.com youxitequ.com;
    #下面这段是域名301跳转,seo的需要,按需配置
    if ($host != 'www.htmlgames.cn' ) {
	rewrite ^/(.*)$ http://www.htmlgames.cn/$1 permanent;
    }

    root  /web/htmlgames/;
  
    location / {
        index  index.html index.php;
        #开启网站的自定义url需要以下配置
	if (-f $request_filename/index.html){
            rewrite (.*) $1/index.html break;
        }
        if (-f $request_filename/index.php){
            rewrite (.*) $1/index.php;
        }
        if (!-f $request_filename){
            rewrite (.*) /index.php;
        }
    }
    #下面配置将php的请求处理交给php容器
    location ~ \.php$ {
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
        include        fastcgi_params;
    }
  
    location ~ /\.ht {
        deny all;
    }
  
    location ~* \.(gif|jpg|png)$ {
        expires 30d;
    }
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   html;
    }
}

使配置生效

nginx -s reload

原创内容转载请保留出处GEEK笔记(http://www.geekapp.cn/)。

分类
IT运维

nginx开启gzip压缩

Gzip是一种数据压缩格式,一般情况下使用Gzip压缩可以达到70%左右的压缩率,例如你的网页是100K,压缩后可以达到30K左右。网站开启 Gzip 压缩功能通常用来节省带宽资源,另外就是加快网页的访问速度。
nginx开启gzip压缩的配置如下:
1、编辑nginx配置文件nginx.conf

vi nginx.conf
#添加如下配置
gzip on;
gzip_min_length 1k;
gzip_buffers 4 8k;
gzip_http_version 1.1;
gzip_comp_level 4;
# nginx: [warn] duplicate MIME type "text/html" in /usr/local/nginx/nginx.conf 提示这个信息,去掉text/html,可能默认已经压缩该格式了
gzip_types text/plain application/javascript application/x-javascript text/javascript text/css application/xml application/json;

2、执行下面的命令检查配置是否正确,若提示successful则配置没有问题

nginx -t

3、加载配置使生效

nginx -s reload

原创内容转载请保留出处GEEK笔记(http://www.geekapp.cn/)。

分类
WEB开发

解决WordPress图片上传时发生错误

刚开始使用wordpress的朋友,可能碰到过图片上传错误的问题,提示:上传时发生了错误,请稍后再试。

解决步骤如下(这里的环境是linux+nginx+mysql+php):

1、检查目录/wp-content/uploads是否存在(若不存在则创建),修改权限为777。

cd wp-content
mkdir uploads
chmod -R 777 uploads

2、修改wp-config.php文件

define('CONCATENATE_SCRIPTS', false);//将这句代码加在文件最后。

3、文件是否过大,php上传文件有大小限制,默认2M,nginx大小限制更低,修改nginx配置上传大小限制如下:

vi nginx.conf
#添加这一行配置
client_max_body_size 2m;
#保存退出vi编辑器
wq

原创内容转载请保留出处GEEK笔记(http://www.geekapp.cn/)。