Ubuntu+lnmp配置多站点方法

Ubuntu+lnmp配置多站点方法

//----------------------------------------------

首先我使用的阿里云,阿里云控制台打开实例;有时候买了阿里的云服务,控制台实例显示会慢半拍,稍等半小时即可;

在实例右边的操作选项里,选择“更多”,选择 安全组配置;

配置规则-入方向-添加安全组规则;打开界面;

端口范围:80/80  (此处) 是打开80端口  ,如开通其他端口则填写相应的端口号用斜杠隔开;

授权对象为 0.0.0.0/0

注意:此处开放的端口,将用于后面的网站服务

//----------------------------------------------

安装lnmp包:

由于我不需要过多的自定义,采取lnmp脚本安装;

lnmp官网 , 下载最新lnmp,个人偏爱nginx,所用的是lnmp,用户可以自行选择要下载的包,可选 lnmp lamp,lnamp;

解压:

tar -zvxf lnmp1.6-full.tar.gz   

进入解压后的文件:

./install lnmp

 安装过程选择版本,数据库管理员用户和密码(这个要记下来,后面用到) ,安装时间约半小时到两小时。

安装期间需要保持联网,如果远程终端断开,则导致安装停止,此时再次登录,reboot系统,再次运行install.sh安装操作。

安装完成后,进入   你的ip:80  可看到lnmp的页面 ,探针和 phpmyadmin可以用起来了。这里不赘述。

创建一个网络用户 ,会自动添加用户组

adduser www

并输入密码

passwd www

//----------------------------------------------

这里站点以 个人博客wordpress 为例:

wordpress:

由于wordpress的特点,需要先行操作数据库

mysql -u root -p 密码

创建数据库

create database wordpress;

权限配置

grant all on wordpress.* to wordpress@'localhost' identified by '密码';
grant all on wordpress.* to wordpress@'%.%.%.%' identified by '密码';
flush privileges;

下载wordpress包;

解压:

unzip WordPress_27492.zip

创建 /var/www/ 目录 将解压的文件复制进入该目录;故有

/var/www/wordpress/

由于wordpress自身特点 需要开放权限,

chmod -R 777 /var/www/wordpress/

此处也可以对该目录 指定特定www用户权限如

chmod -R www:www /var/www/wordpress/

然后开始配置nginx:

查看文件 /usr/local/nginx/conf/nginx.conf 如下

user  www www;

worker_processes auto;
worker_cpu_affinity auto;

error_log  /home/wwwlogs/nginx_error.log  crit;

pid        /usr/local/nginx/logs/nginx.pid;

#Specifies the value for maximum file descriptors that can be opened by this process.
worker_rlimit_nofile 51200;

events
    {
        use epoll;
        worker_connections 51200;
        multi_accept off;
        accept_mutex off;
    }

http
    {
        include       mime.types;
        default_type  application/octet-stream;

        server_names_hash_bucket_size 128;
        client_header_buffer_size 32k;
        large_client_header_buffers 4 32k;
        client_max_body_size 50m;

        sendfile on;
        sendfile_max_chunk 512k;
        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 256k;

        gzip on;
        gzip_min_length  1k;
        gzip_buffers     4 16k;
        gzip_http_version 1.1;
        gzip_comp_level 2;
        gzip_types     text/plain application/javascript application/x-javascript text/javascript text/css application/xml application/xml+rss;
        gzip_vary on;
        gzip_proxied   expired no-cache no-store private auth;
        gzip_disable   "MSIE [1-6]\.";

        #limit_conn_zone $binary_remote_addr zone=perip:10m;
        ##If enable limit_conn_zone,add "limit_conn perip 10;" to server section.

        server_tokens off;
        access_log off;

server
    {
        listen 80 default_server reuseport;
        #listen [::]:80 default_server ipv6only=on;
        server_name 配置访问的地址或域名(如果你有域名的话);
        index index.html index.htm index.php;
        root  /home/wwwroot/default;

        #error_page   404   /404.html;

        # Deny access to PHP files in specific directory
        #location ~ /(wp-content|uploads|wp-includes|images)/.*\.php$ { deny all; }

        include enable-php.conf;

        location /nginx_status
        {
            stub_status on;
            access_log   off;
        }

        location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
        {
            expires      30d;
        }

        location ~ .*\.(js|css)?$
        {
            expires      12h;
        }

        location ~ /.well-known {
            allow all;
        }

        location ~ /\.
        {
            deny all;
        }

        access_log  /home/wwwlogs/access.log;
    }
include vhost/*.conf;
}

 

在最后几行,如果是使用lnmp包安装的,会出现

include vhost/*.conf;

此处是nginx多站点配置的重点,也是方便管理的重点。

/usr/local/nginx/conf/目录下有一个vhost文件,在内部创建wordpress.conf

将/usr/local/nginx/conf/nginx.conf 内server部分填入wordpress.conf

然后进行 端口号 和 IP 的访问,此处的端口号不能是ngnix.conf中已经监听的端口号,否则会发生冲突

server
    {
        listen 配置wordpress访问的端口号 default_server reuseport;
        #listen [::]:80 default_server ipv6only=on;
        server_name 配置访问的IP地址或域名(如果你有域名的话);
        index index.html index.htm index.php;
        root  /var/www/html/wordpress;

        #error_page   404   /404.html;

        # Deny access to PHP files in specific directory
        #location ~ /(wp-content|uploads|wp-includes|images)/.*\.php$ { deny all; }

        include enable-php.conf;

        location /nginx_status
        {
            stub_status on;
            access_log   off;
        }

        location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
        {
            expires      30d;
        }

        location ~ .*\.(js|css)?$
        {
            expires      12h;
        }

        location ~ /.well-known {
            allow all;
        }

        location ~ /\.
        {
            deny all;
        }

        access_log  /home/wwwlogs/access.log;
    }

然后重启 lnmp

lnmp restart

如果显示如下则成功

Stoping LNMP...
Stoping nginx...  done
[ ok ] Stopping mysql (via systemctl): mysql.service.
Gracefully shutting down php-fpm . done
Starting LNMP...
Starting nginx...  done
[ ok ] Starting mysql (via systemctl): mysql.service.
Starting php-fpm  done

此时从浏览器中打入

IP:port 即可查看配置的站点,此处我配置的是 80 和 911 端口

有 xxx.xxx.xxx.xxx:80   xxx.xxx.xxx.xxx:911 查看网页

本人将wordpress 配置到了911上,则进入网页能看到wordpress的安装界面。

安装过程会要求输入数据库密码,由上面查得。

enjoy it !

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值