nginx搭建

第一步:从http://nginx.org/download/上... http://nginx.org/download/nginx-1.5.9.tar.gz直接在Linux上用命令下载)
第二步:解压 tar -zxvf nginx-1.5.9.tar.gz
第三步:
为了后续准备我们另外下载2个插件模块:nginx_upstream_check_module-0.3.0.tar.gz(检查后端服务器的状态),
nginx-goodies-nginx-sticky-module-ng-bd312d586752.tar.gz(建议在/usr/local/src下解压后将目录重命名为nginx-sticky-module-ng-1.2.5)
后端做负载均衡解决session sticky问题(与upstream_check模块结合使用需要另外打补丁,请参考nginx负载均衡配置实战)。
nginx-goodies-nginx-sticky-module-ng-bd312d586752.tar.gz作用:后端做负载均衡解决session sticky问题

https://github.com/yaoweibin/nginx_upstream_check_module/releases

nginx_upstream_check_module-0.3.0.tar.gz作用:检查后端服务器的状态

https://bitbucket.org/nginx-goodies/nginx-sticky-module-ng/downloads

请注意插件与nginx的版本兼容问题,一般插件越新越好,nginx不用追新,稳定第一。nginx-1.4.7,nginx-sticky-module-1.1,nginx_upstream_check_module-0.2.0,
这个搭配也没问题。sticky-1.1与nginx-1.6版本由于更新没跟上编译出错。(可以直接使用Tengine,默认就包括了这些模块)

安装配置一:

./configure --prefix=/usr/local/nginx-1.6 --with-pcre=../pcre-8.31 \
   > --with-http_stub_status_module --with-http_ssl_module \
   > --with-http_gzip_static_module --with-http_realip_module \
   > --add-module=../nginx_upstream_check_module-0.3.0 

安装配置二:

./configure \
> --prefix=/usr \
> --sbin-path=/usr/sbin/nginx \
> --conf-path=/etc/nginx/nginx.conf \
> --error-log-path=/var/log/nginx/error.log \
> --http-log-path=/var/log/nginx/access.log \
> --pid-path=/var/run/nginx/nginx.pid \
> --lock-path=/var/lock/nginx.lock \
> --user=nginx \
> --group=nginx \
> --with-http_ssl_module \
> --with-http_stub_status_module \
> --with-http_gzip_static_module \
> --http-client-body-temp-path=/var/tmp/nginx/client/ \
> --http-proxy-temp-path=/var/tmp/nginx/proxy/ \
> --http-fastcgi-temp-path=/var/tmp/nginx/fcgi/ \
> --http-uwsgi-temp-path=/var/tmp/nginx/uwsgi \
> --with-pcre=../pcre-7.8
> --with-zlib=../zlib-1.2.3

常用编译选项说明
nginx大部分常用模块,编译时./configure --help以--without开头的都默认安装。
--prefix=PATH : 指定nginx的安装目录。默认 /usr/local/nginx
--conf-path=PATH : 设置nginx.conf配置文件的路径。nginx允许使用不同的配置文件启动,通过命令行中的-c选项。默认为prefix/conf/nginx.conf
--user=name: 设置nginx工作进程的用户。安装完成后,可以随时在nginx.conf配置文件更改user指令。默认的用户名是nobody。--group=name类似
--with-pcre : 设置PCRE库的源码路径,如果已通过yum方式安装,使用--with-pcre自动找到库文件。使用--with-pcre=PATH时,
需要从PCRE网站下载pcre库的源码(版本4.4 – 8.30)并解压,剩下的就交给Nginx的./configure和make来完成。perl正则表达式使用在location指令和 ngx_http_rewrite_module模块中。
--with-zlib=PATH : 指定 zlib(版本1.1.3 – 1.2.5)的源码解压目录。在默认就启用的网络传输压缩模块ngx_http_gzip_module时需要使用zlib 。
--with-http_ssl_module : 使用https协议模块。默认情况下,该模块没有被构建。前提是openssl与openssl-devel已安装
--with-http_stub_status_module : 用来监控 Nginx 的当前状态
--with-http_realip_module : 通过这个模块允许我们改变客户端请求头中客户端IP地址值(例如X-Real-IP 或 X-Forwarded-For),意义在于能够使得后台服务器记录原始客户端的IP地址
--add-module=PATH : 添加第三方外部模块,如nginx-sticky-module-ng或缓存模块。每次添加新的模块都要重新编译(Tengine可以在新加入module时无需重新编译)
第四步:
make 编译 (make的过程是把各种语言写的源码文件,变成可执行文件和各种库文件)
make install 安装 (make install是把这些编译出来的可执行文件和库文件复制到合适的地方)
第五步:启动关闭nginx
检查配置文件是否正确
$/usr/local/nginx-1.6/sbin/nginx -t
$./sbin/nginx -V #可以看到编译选项
启动、关闭
$./sbin/nginx # 默认配置文件 conf/nginx.conf,-c 指定
$./sbin/nginx -s stop
或 pkill nginx
重启,不会改变启动时指定的配置文件
$./sbin/nginx -s reload
或 kill -HUP cat /usr/local/nginx-1.6/logs/nginx.pid
当然也可以将 nginx 作为系统服务管理,下载 nginx 到/etc/init.d/,修改里面的路径然后赋予可执行权限。

关注公众号获取海量视频
图片描述

Sticky是nginx的一个模块,它是基于cookie的一种nginx的负载均衡解决方案,通过分发和识别cookie,来使同一个客户端的请求落在同一台服务器上,默认标识名为route (a)客户端首次发起访问请求,nginx接收后,发现请求头没有cookie,则以轮询方式将请求分发给后端服务器。 (b)后端服务器处理完请求,将响应数据返回给nginx。 (c)此时nginx生成带route的cookie,返回给客户端。route的值与后端服务器对应,可能是明文,也可能是md5、sha1等Hash值 (d)客户端接收请求,并保存带route的cookie。 (e)当客户端下一次发送请求时,会带上route,nginx根据接收到的cookie中的route值,转发给对应的后端服务器。 其他需要注意的 (a)同一客户端的请求,有可能落在不同的后端服务器上。如果客户端启动时同时发起多个请求。由于这些请求都没带cookie,所以服务器会随机选择后端服务器,返回不同的cookie。当这些请求中的最后一个请求返回时,客户端的cookie才会稳定下来,值以最后返回的cookie为准。 (b)cookie不一定生效。由于cookie最初由服务器端下发,如果客户端禁用cookie,则cookie不会生效。 (c)客户端可能不带cookie。Android客户端发送请求时,一般不会带上所有的cookie,需要明确指定哪些cookie会带上。如果希望用sticky做负载均衡,请对Android开发说加上cookie。 (d)cookie名称不要和业务使用的cookie重名。Sticky默认的cookie名称是route,可以改成任何值。 (e)客户端发的第一个请求是不带cookie的。服务器下发的cookie,在客户端下一次请求时才能生效。 (f)Nginx sticky模块不能与ip_hash同时使用 sticky [name=route] [domain=.foo.bar] [path=/] [expires=1h] [hash=index|md5|sha1] [no_fallback] [secure] [httponly]; [name=route] 设置用来记录会话的cookie名称 [domain=.foo.bar] 设置cookie作用的域名 [path=/] 设置cookie作用的URL路径,默认根目录 [expires=1h] 设置cookie的生存期,默认不设置,浏览器关闭即失效,需要是大于1秒的值 [hash=index|md5|sha1] 设置cookie中服务器的标识是用明文还是使用md5值,默认使用md5 [no_fallback] 设置该项,当sticky的后端机器挂了以后,nginx返回502 (Bad Gateway or Proxy Error) ,而不转发到其他服务器,不建议设置 [secure] 设置启用安全的cookie,需要HTTPS支持 [httponly] 允许cookie不通过JS泄漏,没用过
使用nginx搭建服务器地图可按以下步骤进行: 1. **上传离线地图**:用xftp上传离线地图到服务器[^1]。 2. **修改配置文件**:使用`vim /usr/local/nginx/conf/nginx.conf`命令修改配置文件,添加新的server,示例如下: ```plaintext server { listen 8081; # 监听8081端口 server_name localhost:8081; location /mapdata { # 匹配mapdata alias /disk/offlineMap; # 映射到/disk/offlineMap文件夹 } } ``` 修改完成后,重新载入配置文件,命令为`/usr/local/nginx/sbin/nginx -s reload` [^1]。 3. **配置天地图缓存(可选)**:若有需要配置天地图缓存,可在`nginx.conf`文件中添加如下内容: ```plaintext upstream tianditu_server { server t0.tianditu.com weight=1 max_fails=3 fail_timeout=20s; server t1.tianditu.com weight=1 max_fails=3 fail_timeout=20s; server t2.tianditu.com weight=1 max_fails=3 fail_timeout=20s; server t3.tianditu.com weight=1 max_fails=3 fail_timeout=20s; server t4.tianditu.com weight=1 max_fails=3 fail_timeout=20s; server t5.tianditu.com weight=1 max_fails=3 fail_timeout=20s; server t6.tianditu.com weight=1 max_fails=3 fail_timeout=20s; server t7.tianditu.com weight=1 max_fails=3 fail_timeout=20s; } ``` [^3] 4. **启动nginx**: - 开启服务:在Windows下可直接点击Nginx目录下的`nginx.exe`;在Linux下,启动命令为`start nginx`。 - 停止服务:`nginx -s stop`(快速停止,可能不保存相关信息);`nginx -s quit`(完整有序停止,并保存相关信息)。还可通过以下命令停止: - 从容停止Nginx:`kill -QUIT 主进程号`。 - 快速停止Nginx:`kill -TERM 主进程号`。 - 强制停止Nginx:`pkill -9 nginx`。 - 平滑重启nginx:`kill -HUP 主进程号`。 - 重启服务:`nginx -s reload`。 - 检查配置文件是否有语法错误:`./nginx -t` 或者显示指定配置文件`./nginx -t -c /usr/local/nginx/conf/nginx.conf` [^4]。 5. **访问测试**:访问图片,查看是否成功加载地图 [^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值