首页 > 代码库 > 以非root权限安装nginx及运行

以非root权限安装nginx及运行

本章主要讲如何在无root权限(包含无sudo权限)条件下于centos命令行中安装nginx以及在大于1024的端口(这里用8080)上运行。

1. 安装

两种方式,一是下载预编译好的rpm包安装,二是下载源码后自己编译。

如果是通过下载rpm方式安装,首先要找对应centos版本的rpm包。

通过命令

cat /etc/*release*

的输出可以看到centos系统的版本,在我能访问的某个云主机上显示如下:

 技术分享

使用curl -G <URL>命令来浏览网址http://nginx.org/packages/centos/$ver的内容,其中$ver为centos版本值为5或6或7(其实这个也可通过浏览网址http://nginx.org/packages/centos/)查看到,6.x版本对应是6,故浏览http://nginx.org/packages/centos/6,有如下输出:

 技术分享

找到对应cpu架构,64位cpu为x86_64,因此浏览http://nginx.org/packages/centos/6/x86_64/,进入RPMS目录(即浏览http://nginx.org/packages/centos/6/x86_64/RPMS/),查看其中的超链接,如:<a href=http://www.mamicode.com/“nginx-1.8.1-1.el6.ngx.x86_64.rpm”>nginx-1.8.1-1.el6.ngx.x86_64.rpm,选择其中的版本(这里是版本1.8.1),根据超链(href="...")使用wget下载:

wget http://nginx.org/packages/centos/6/x86_64/RPMS/nginx-1.8.1-1.el6.ngx.x86_64.rpm

完成后在当前目录有对应rpm文件,但是不能直接安装改rpm,因为权限限制,因此我们不安装,而是提取出其中的二进制(及其他必要文件),通过以下命令实现:

rpm2cpio ctags-5.8-2.el6.x86_64.rpm |cpio -idvm

此时当前文件夹下多出etc、usr等文件夹,其中usr/sbin/nginx就是nginx的二进制文件,可选择性地将其移动到~/bin/目录下。

至此nginx的二进制文件已有,算是”安装“上了。

2. 配置及运行

nginx根据默认配置会导致读写需要root权限的文件和目录,因此需要提供自定义配置文件。新建一个nginx.conf文件,填入以下内容:

# Usage: nginx -c /path/to/this/nginx.conferror_log /tmp/error.log;pid /tmp/nginx.pid;worker_processes 1;events {  worker_connections 1024;} http {  # Set an array of temp and cache file options that will otherwise default to  # restricted locations accessible only to root.  client_body_temp_path /tmp/client_body;  fastcgi_temp_path /tmp/fastcgi_temp;  proxy_temp_path /tmp/proxy_temp;  scgi_temp_path /tmp/scgi_temp;  uwsgi_temp_path /tmp/uwsgi_temp;   tcp_nopush on;  tcp_nodelay on;  keepalive_timeout 65;  types_hash_max_size 2048;   #include /etc/nginx/mime.types;  index index.html index.htm index.php;   log_format   main $remote_addr - $remote_user [$time_local] $status     "$request" $body_bytes_sent "$http_referer"     "$http_user_agent" "$http_x_forwarded_for";   default_type application/octet-stream;   server {    # IPv4.    listen 8080;    # IPv6.    #listen [::]:8080 default ipv6only=on;     root /path/to/html/root;     access_log /tmp/access.log;    error_log /tmp/error.log;     location / {      # First attempt to serve request as file, then as directory, then fall      # back to index.html.      try_files $uri $uri/ /index.html;    }  }}

 

我们需要告诉nginx我们的html(web应用的根目录)放在哪里,通过修改文件结构中http块下server块中的root实现(即上例文件中的root /path/to/html/root; 行,注意行末有分号),这里最好配置为绝对路径。nginx在软件包中提供了一个很简单的html页面,在解压出中的目录usr/share/html中,可以使用这个html目录测试。配置文件中的大部分值为路径,我们的目的就是要将覆盖默认路径,改到我们有权限读写的路径中(上示例文件中大部分配置到/tmp目录去了)。

通过命令行参数告知nginx我们的配置文件(而非使用默认的配置文件):

 

nginx -c /home/xxxx/nginx.conf #配置文件的绝对路径

 

nginx有可能仍会提示无权限打开/var/log/nginx/error.log,无视之,可使用pgrep -a nginx看到nginx已经运行。通过curl <本机ip或localhost>:8080看到nginx自己做的欢迎页面,我这里的显示如下:

 技术分享

至此,nginx在无root权限下成功运行。

 

通过下载源码编译安装方式,一定要记得配置前缀路径,否则会因无权限写入/usr, /etc等默认路径下的文件而失败,编译后的目录结构上面由rpm包解压出的结构类似,配置及运行的过程一样。

以非root权限安装nginx及运行