Nginx的安装与部署

来源:互联网 发布:数码大师类似软件 编辑:程序博客网 时间:2024/05/19 13:17

1:安装工具包 wget、vim和gcc

yum install -y wget  yum install -y vim-enhanced  yum install -y make cmake gcc gcc-c++  

2:下载nginx安装包

wget http://nginx.org/download/nginx-1.6.2.tar.gz

3:安装依赖包

yum install -y pcre pcre-develyum install -y zlib zlib-develyum install -y openssl openssl-devel

4:解压nginx-1.6.2.tar.gz到/usr/local/目录下

tar -zxvf nginx-1.6.2.tar.gz -C /usr/local/

5:进行configure配置

进入nginx-1.6.2目录然后在执行./configure命令

[root@MiWiFi-R3-srv nginx-1.6.2]# ./configure --prefix=/usr/local/nginx

6:编译安装

[root@MiWiFi-R3-srv nginx-1.6.2]# make && make install

7:启动Nginx,启动完之后检查nginx是否已经正常启动,看到如下信息说明正常启动

[root@MiWiFi-R3-srv nginx-1.6.2]# /usr/local/nginx/sbin/nginx[root@MiWiFi-R3-srv nginx-1.6.2]# ps -ef | grep nginxroot     24956     1  0 19:41 ?        00:00:00 nginx: master process /usr/local/nginx/sbin/nginxnobody   24957 24956  0 19:41 ?        00:00:00 nginx: worker processroot     24959 10533  0 19:41 pts/0    00:00:00 grep --color=auto nginx[root@MiWiFi-R3-srv nginx-1.6.2]# 

如果要关闭nginx,我们可以使用如下命令:

  [root@MiWiFi-R3-srv nginx-1.6.2]# /usr/local/nginx/sbin/nginx -s stop

如果想要重新热启动nginx,则使用如下命令:

  [root@MiWiFi-R3-srv nginx-1.6.2]# /usr/local/nginx/sbin/nginx -s reload

8:配置防火墙,nginx默认的端口是80

[root@MiWiFi-R3-srv nginx-1.6.2]# firewall-cmd --zone=public --add-port=80/tcp --permanentsuccess[root@MiWiFi-R3-srv nginx-1.6.2]# firewall-cmd --reloadsuccess[root@MiWiFi-R3-srv nginx-1.6.2]# 

9:测试nginx

通过浏览器访问nginx欢迎页,在地址栏输入:http://192.168.31.241/(80端口可以不用输)或http://192.168.156.11:80/,如下图所示。

这里写图片描述


10:学习nginx配置

在nginx目录下进入conf目录,该目录下有个nginx.conf文件,这是nginx最重要的配置文件

[root@MiWiFi-R3-srv conf]# vim /usr/local/nginx/conf/nginx.conf

nginx.conf文件的全部内容如下(有注释版):

 #user  nobody;  #开启进程数 <=CPU数   worker_processes  1;  #错误日志保存位置  #error_log  logs/error.log;  #error_log  logs/error.log  notice;  #error_log  logs/error.log  info;  #进程号保存文件  #pid        logs/nginx.pid;  #每个进程最大连接数(最大连接=连接数x进程数)每个worker允许同时产生多少个链接,默认1024  events {      worker_connections  1024;  }  http {      #文件扩展名与文件类型映射表      include       mime.types;      #默认文件类型      default_type  application/octet-stream;      #日志文件输出格式 这个位置相于全局设置      #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '      #                  '$status $body_bytes_sent "$http_referer" '      #                  '"$http_user_agent" "$http_x_forwarded_for"';      #请求日志保存位置      #access_log  logs/access.log  main;      #打开发送文件      sendfile        on;      #tcp_nopush     on;      #keepalive_timeout  0;      #连接超时时间      keepalive_timeout  65;      #打开gzip压缩      #gzip  on;      server {          #监听端口,默认是80端口          listen       80;          #监听域名          server_name  localhost;          #charset koi8-r;          #nginx访问日志放在logs/host.access.log下,并且使用main格式(还可以自定义格式)          #access_log  logs/host.access.log  main;          #如果没有location更明确的匹配访问路径的话,访问请求都会被该location处理。          location / {              #root指定nginx的根目录为/usr/local/nginx/html              root   html;              #默认访问文件,欢迎页先去html目录下找index.html,如果找不到再去找index.htm              index  index.html index.htm;          }          #error_page  404              /404.html;          # redirect server error pages to the static page /50x.html          #          #错误页面及其返回地址,错误码为500、502、503、504都会返回50.html错误页面。          error_page   500 502 503 504  /50x.html;          #location后面是"="的话,说明是精确匹配          location = /50x.html {              root   html;          }          # proxy the PHP scripts to Apache listening on 127.0.0.1:80          #          #location ~ \.php$ {          #    proxy_pass   http://127.0.0.1;          #}          # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000          #          #location ~ \.php$ {          #    root           html;          #    fastcgi_pass   127.0.0.1:9000;          #    fastcgi_index  index.php;          #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;          #    include        fastcgi_params;          #}          # deny access to .htaccess files, if Apache's document root          # concurs with nginx's one          #          #location ~ /\.ht {          #    deny  all;          #}      }      # another virtual host using mix of IP-, name-, and port-based configuration      #      #server {      #    listen       8000;      #    listen       somename:8080;      #    server_name  somename  alias  another.alias;      #    location / {      #        root   html;      #        index  index.html index.htm;      #    }      #}      # HTTPS server      #      #server {      #    listen       443 ssl;      #    server_name  localhost;      #    ssl_certificate      cert.pem;      #    ssl_certificate_key  cert.key;      #    ssl_session_cache    shared:SSL:1m;      #    ssl_session_timeout  5m;      #    ssl_ciphers  HIGH:!aNULL:!MD5;      #    ssl_prefer_server_ciphers  on;      #    location / {      #        root   html;      #        index  index.html index.htm;      #    }      #}  }  

配置文件里可以添加多个server,server监听的端口不同,可以根据需要让nginx代理多个端口,当访问某个端口的时候,指定去做某些事情。我这里添加了一个server,这个server监听的端口为1234,server_name我指定为了test.com,也就是域名为test.com,当访问1234端口时会自动导航到/usr/local/nginx/tester/tester111.html页面,如下所示。

#user  nobody;  #开启进程数 <=CPU数   worker_processes  1;  #错误日志保存位置  #error_log  logs/error.log;  #error_log  logs/error.log  notice;  #error_log  logs/error.log  info;  #进程号保存文件  #pid        logs/nginx.pid;  #每个进程最大连接数(最大连接=连接数x进程数)每个worker允许同时产生多少个链接,默认1024  events {      worker_connections  1024;  }  http {      #文件扩展名与文件类型映射表      include       mime.types;      #默认文件类型      default_type  application/octet-stream;      #日志文件输出格式 这个位置相于全局设置      #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '      #                  '$status $body_bytes_sent "$http_referer" '      #                  '"$http_user_agent" "$http_x_forwarded_for"';      #请求日志保存位置      #access_log  logs/access.log  main;      #打开发送文件      sendfile        on;      #tcp_nopush     on;      #keepalive_timeout  0;      #连接超时时间      keepalive_timeout  65;      #打开gzip压缩      #gzip  on;      server {          #监听端口          listen       80;          #监听域名          server_name  localhost;          #charset koi8-r;          #nginx访问日志放在logs/host.access.log下,并且使用main格式(还可以自定义格式)          #access_log  logs/host.access.log  main;          #如果没有location更明确的匹配访问路径的话,访问请求都会被该location处理。          location / {              #root指定nginx的根目录为/usr/local/nginx/html              root   html;              #默认访问文件,欢迎页先去html目录下找index.html,如果找不到再去找index.htm              index  index.html index.htm;          }          #error_page  404              /404.html;          # redirect server error pages to the static page /50x.html          #          #错误页面及其返回地址,错误码为500、502、503、504都会返回50.html错误页面。          error_page   500 502 503 504  /50x.html;          #location后面是"="的话,说明是精确匹配          location = /50x.html {              root   html;          }          server {              listen 1234;              server_name test.com;              location / {                  #正则表达式匹配uri方式:在/usr/local/nginx/tester下 建立一个tester111.html 然后使用正则匹配                  root tester;                  index tester111.html;              }          }      }  }  

如果您喜欢这篇文章就请关注我的博客和朋友一起分享吧!
关注我: ☛ http://blog.csdn.net/yougoule

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 一个人欠我钱跑了我该怎么办 买房子时间长了成危楼了怎么办 别人欠我钱人找不到了怎么办 欠银行信用卡钱人失踪了怎么办 欧洲卡车模拟2没油了怎么办 蓝牙安装包里没有微信怎么办 腾讯手游模拟器玩全军出击卡怎么办 手游cf用模拟器画面很抖怎么办 腾讯手游助手模拟器游戏卡死怎么办 腾讯手游模拟器提示注册以满怎么办 手游绝地求生被检测成模拟器怎么办 腾讯手游助手模拟器内存不够怎么办 微信视频对方听不到我的声音怎么办 学生考试传纸条作弊老师应怎么办 苹果手机微信小游戏没有声音怎么办 红米手机游戏下好了安装不了怎么办 小米手机sd卡存储已满怎么办 英雄联盟峡谷之巅资格被收回怎么办 人进监狱之前信用卡没还怎么办 荒野行动资源文件下载卡住了怎么办 荒野行动绑定的手机号停机了怎么办 不小心误点了爱奇艺扣款了怎么办 和别人吵架别人先骂你怎么办 自己人被带到了缅甸黑社会了怎么办 绝地求生忘记复制钥匙激活码怎么办 绝地求生买的钥匙激活码丢了怎么办 蓝河奶粉宝宝吃了不长肉怎么办 苹果ios版本太低激活不了怎么办 脸上被油烫伤了 起了水泡怎么办 皮肤被油烫伤起来个水泡怎么办 去泰国旅游没来得及兑换泰铢怎么办 游戏和安卓 不和 出现黑屏怎么办 邻居把垃圾放在楼梯口不丢怎么办 58热敏小票打印机口松了怎么办 王鹏的眼睛今天起疙瘩了怎么办 背包带子老从肩膀滑下来怎么办 绝地求生用手机流量更新不成怎么办 手机拍的视频在电脑上放不了怎么办 炉石传说手机点登陆游戏闪退怎么办 车到信号屏蔽区一键启动不了怎么办 王者荣耀战队活跃度满了怎么办