領了一個亞馬遜的1年免費服務器,今天嘗試安裝 Nginx 服務器,使用原生的 Shell 方法。javascript
爲了方便之後查看,就把過程記錄一下。php
注意:亞馬遜(AWS)服務器默認只能用 user-ec2 帳戶進行登錄,須要切換一下,使用 root 帳戶登錄。不然會由於權限不夠,致使一些軟件或功能沒法安裝。css
參考我以前的文章:使用Xshell登陸亞馬遜AWS EC2服務器&配置root+密碼方式登陸html
系統平臺:Amazon Linux 2 AMI (HVM)java
yum -y install make zlib zlib-devel gcc-c++ libtool openssl openssl-devel
PCRE 做用是讓 Nginx 支持 Rewrite 功能。node
注:須要按步驟一步一步操做,特別注意目錄。linux
一、下載 PCRE 安裝包:nginx
插:這裏可能會提示 -bash: wget: command not found
web
須要安裝 wget 下載工具:若已安裝,直接跳過便可shell
yum -y install wget
安裝完成便可繼續操做。
下載 PCRE 安裝包,下載地址:https://pilotfiber.dl.sourceforge.net/project/pcre/pcre/8.43/pcre-8.43.tar.gz
cd /usr/local/src/ wget https://pilotfiber.dl.sourceforge.net/project/pcre/pcre/8.43/pcre-8.43.tar.gz
二、解壓安裝包:
tar zxvf pcre-8.43.tar.gz
三、進入安裝包目錄
cd pcre-8.43
四、編譯安裝
這裏可能會提示 -bash: make: command not found
,參考上面 wget 的安裝,若是已經安裝直接跳過。
yum -y install gcc automake autoconf libtool make
而後繼續操做,編譯安裝:
./configure make make install
五、查看 PCRE 版本
pcre-config --version
一、下載 Nginx,下載地址:http://nginx.org/download/nginx-1.16.0.tar.gz
cd /usr/local/src/ wget http://nginx.org/download/nginx-1.16.0.tar.gz
二、解壓安裝包
tar zxvf nginx-1.16.0.tar.gz
三、進入安裝包目錄
cd nginx-1.16.0
四、編譯安裝
./configure --prefix=/usr/local/webserver/nginx --with-http_stub_status_module --with-http_ssl_module --with-pcre=/usr/local/src/pcre-8.43 make make install
注意,此處用 pcre2 make 會報錯,建議老實用 pcre ,別問我是怎麼知道的。
五、查看nginx版本
/usr/local/webserver/nginx/sbin/nginx -v
至此,nginx安裝完成。
建立 Nginx 運行使用的用戶 www:
/usr/sbin/groupadd www /usr/sbin/useradd -g www www
配置 nginx.conf ,將 /usr/local/webserver/nginx/conf/nginx.conf 替換爲如下內容:
cat /usr/local/webserver/nginx/conf/nginx.conf user www www; worker_processes 2; #設置值和CPU核心數一致 error_log /usr/local/webserver/nginx/logs/nginx_error.log crit; #日誌位置和日誌級別 pid /usr/local/webserver/nginx/nginx.pid; #Specifies the value for maximum file descriptors that can be opened by this process. worker_rlimit_nofile 65535; events { use epoll; worker_connections 65535; } 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'; #charset gb2312; server_names_hash_bucket_size 128; client_header_buffer_size 32k; large_client_header_buffers 4 32k; client_max_body_size 8m; sendfile on; tcp_nopush on; keepalive_timeout 60; tcp_nodelay on; fastcgi_connect_timeout 300; fastcgi_send_timeout 300; fastcgi_read_timeout 300; fastcgi_buffer_size 64k; fastcgi_buffers 4 64k; fastcgi_busy_buffers_size 128k; fastcgi_temp_file_write_size 128k; gzip on; gzip_min_length 1k; gzip_buffers 4 16k; gzip_http_version 1.0; gzip_comp_level 2; gzip_types text/plain application/x-javascript text/css application/xml; gzip_vary on; #limit_zone crawler $binary_remote_addr 10m; #下面是server虛擬主機的配置 server { listen 80;#監聽端口 server_name localhost;#域名 index index.html index.htm index.php; root /usr/local/webserver/nginx/html;#站點目錄 location ~ .*\.(php|php5)?$ { #fastcgi_pass unix:/tmp/php-cgi.sock; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; include fastcgi.conf; } location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|ico)$