centos上部署nginx服务

Nginx ("engine x") 是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器。Nginx是由Igor Sysoev为俄罗斯访问量第二的Rambler.ru站点开发的,第一个公开版本0.1.0发布于2004年10月4日。其将源代码以类BSD许可证的形式发布,因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。2011年6月1日,nginx 1.0.4发布。Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行。由俄罗斯的程序设计师Igor Sysoev所开发,供俄国大型的入口网站及搜索引擎Rambler(俄文:Рамблер)使用。其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。

主要作用: 轻量级的Web 服务器和反向代理服务器

一、软件安装

yum安装

1.先安装epel-release扩展包

2.在安装nginx服务

yum install nginx

3.修改配置文件

vim /etc/nginx/nginx.conf

 1 #用户是nginx
 2 user nginx;
 3 #工作进程自动(有多少cpu就开多少进程)
 4 worker_processes auto;
 5 #错误日志
 6 error_log /var/log/nginx/error.log;
 7 
 8 
 9 pid /run/nginx.pid;
10 
11 # Load dynamic modules. See /usr/share/nginx/README.dynamic.
12 include /usr/share/nginx/modules/*.conf;
13 
14 events {
15     #一个进程里边开多少个线程
16     worker_connections 1024;
17 }
18 
19 http {
20     log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
21                       '$status $body_bytes_sent "$http_referer" '
22                       '"$http_user_agent" "$http_x_forwarded_for"';
23     #访问日志
24     access_log  /var/log/nginx/access.log  main;
25 
26     sendfile            on;
27     tcp_nopush          on;
28     tcp_nodelay         on;
29     keepalive_timeout   65;
30     types_hash_max_size 2048;
31 
32     include             /etc/nginx/mime.types;
33     default_type        application/octet-stream;
34 
35     # Load modular configuration files from the /etc/nginx/conf.d directory.
36     # See http://nginx.org/en/docs/ngx_core_module.html#include
37     # for more information.
38     # 可自定义的配置文件
39     include /etc/nginx/conf.d/*.conf;
40 
41     server {
42         #监听的端口号
43         listen       80 default_server;
44         listen       [::]:80 default_server;
45         server_name  _;
46         #网站的根目录
47         root         /usr/share/nginx/html;
48 
49         # Load configuration files for the default server block.
50         include /etc/nginx/default.d/*.conf;
51 
52         location / {
53         }
54 
55         error_page 404 /404.html;
56             location = /40x.html {
57         }
58 
59         error_page 500 502 503 504 /50x.html;
60             location = /50x.html {
61         }
62     }
View Code

保存配置文件,启动nginx服务->systemctl start nginx(最好是systemctl reload nginx) 如果访问不了,关闭防火墙,systemctl stop firewalld 启动浏览器,访问刚刚安装并配置了nginx的Linux服务器地址

二进制安装

NFS 是Network File System的缩写,即网络文件系统。一种使用于分散式文件系统的协定,由Sun公司开发,于1984年向外公布。功能是通过网络让不同的机器、不同的操作系统能够彼此分享个别的数据,让应用程序在客户端通过网络访问位于服务器磁盘中的数据,是在类Unix系统间实现磁盘文件共享的一种方法。
  NFS 的基本原则是“容许不同的客户端及服务端通过一组RPC分享相同的文件系统”,它是独立于操作系统,容许不同硬件及操作系统的系统共同进行文件的分享。
  NFS在文件传送或信息传送过程中依赖于RPC协议。RPC,远程过程调用 (Remote Procedure Call) 是能使客户端执行其他系统中程序的一种机制。NFS本身是没有提供信息传输的协议和功能的,但NFS却能让我们通过网络进行资料的分享,这是因为NFS使用了一些其它的传输协议。而这些传输协议用到这个RPC功能的。可以说NFS本身就是使用RPC的一个程序。或者说NFS也是一个RPC SERVER。所以只要用到NFS的地方都要启动RPC服务,不论是NFS SERVER或者NFS CLIENT。这样SERVER和CLIENT才能通过RPC来实现PROGRAM PORT的对应。可以这么理解RPC和NFS的关系:NFS是一个文件系统,而RPC是负责负责信息的传输。

二、软件安装及使用

  • 在服务器端机器上创建一个共享的目录,并修改配置文件/etc/exports,增加【/share 192.168.31.0/24(rw,sync,fsid=0)】,然后保存配置文件,并使用exportfs或者showmount -e查看是否启动配置成功
  • mkdir /share---->echo 123123>/sharea.txt
  • vim /etc/exports------>增加/share 192.168.31.0/24(rw,sync,fsid=0)
  • systemctl start rpcbind.service------>开启rpc服务
  • systemctl start bfs-server.service------>开启nfs服务
  • chmod -R O=rwx /share------>修改权限,让其他web服务器这个文件夹有修改权限

 

  • 另外开两台web服务器,都部署好nginx,在web服务器使用 showmount -e 192.168.31.146查看共享内容

 

  • 在web服务器上,将共享目录,挂载到本地 mount -t nfs 192.168.31.146:/share /usr/share/nginx/html
  • 在web服务器上,techo 123 /usr/share/nginx/html/share.txt
    修改共享目录的文件内容
  • 在nfs服务器上tail -1 /share/share.txt
    ,可以看到内容被web1上编辑为‘123’了

三、步骤和原理

  • 部署两台web服务器
  • 部署一台使用nginx做反向代理服务器,使用三种模式作负载均衡
  1. round-robin:轮循-将网页请求按照顺序向web服务器分配,反复的执行这样的过程,比如请求1给web1,请求2给web2,请求3再给web1
  2. least-connected:最小链接调度-比如web1当前有100个链接,web2只有一个链接,那下次来的请求将分配给web2服务器
  3. ip-hash:根据请求的ip地址,去访问上次已经访问过的web服务器,也叫会话保持
  • 使用nfs作共享存储

四、示例步骤

1.准备两台web服务器,一台反向代理服务器,一台共享存储服务器。均安装nginx和nfs

2.在反向代理服务器上修改 --->vim /etc/nginx/nginx.conf为----->round-robin

定义一组nginx要管理的web组
upstream myapp1{
    server 192.168.31.144;
    server 192.168.31.145;        
}

在location中自定义要启用的管理组
location / {
    proxy_pass http://myapp1;
}

3.在web服务器上修改 --->vim /etc/nginx/nginx.conf

bash 在网站根目录下,自定义web1.txt,echo web>>web1.txt<br/> 设置网站根目录优先查找的文件为自定义的文件

 

bash 访问nginx代理服务器

4.制作nfs服务器(参考nfs安装及使用)

已经创建了一台nfs服务器,共享了一个/share文件夹
将nfs共享磁盘挂载到网站根目录下--->mount -t nfs 192.168.31.147:/share /usr/share/nginx/html
并且修改web1和web2的vim /etc/nginx/nginx.conf,定义index为share.txt

5.使用浏览器访问nginx服务器,服务器就去轮循访问web1和web2(就是访问nfs服务器上的share.txt)

 

posted @ 2017-08-27 15:05  ForeverPine  阅读(960)  评论(0编辑  收藏  举报
TOP