从零开始在linux下搭建wordpress博客

一,准备linux环境
本地虚拟机能够忽略第一部分

 

微博以及微信的公共平台如今正火的一塌糊涂。既然博客已经上线,准备把一些过程写一下,省的之后我本身忘了。就当留个记念吧,好歹花了这么长时间。php


全文的操做环境为debian。其余linux发行版区别不大。html


没有vps的能够在电脑上装个linux虚拟机试试,都同样的。mysql



登入vps


Windows下我一直用的是putty,linux下就很少讲了,ssh就行。在linux的shell下输密码是不显示的。


修改root密码
  1. passwd
复制代码

添加新用户linux


一天到晚用root进行操做我以为是件蛮危险的事…
  1. adduser username
复制代码

username改为你本身的。nginx


新用户添加到sudo


就是给用户添加root权限。
  1. nano /etc/sudoers
复制代码

找到User privilege specification,在下面插入一行web

  1. username    ALL=(ALL:ALL) ALL
复制代码

cntrl+o 写入,cntrl+x退出,也能够直接cntrl+x退出,会提示是否保存修改,输入y保存,cntrl+c取消返回。若系统没安装sudo:sql

  1. apt-get update
  2. apt-get upgrade
  3. apt-get install sudo
复制代码

修改SSH配置文件(谨慎操做)shell


ssh的配置文件默认应该在/etc/ssh/ssh_config,ssh默认使用的端口是22,我的认为使用默认端口是不大安全的。因为1024如下的端口是被linux系统占用的,因此咱们改个1025到65536就好。打开配置文件数据库

  1. nano /etc/ssh/sshd_config
复制代码

找到port 22这一行,好比改成2222apache

  1. port 2222
复制代码

禁止root帐户远程链接:

  1. PermitRootLogin no
复制代码

仅使用 SSH Protocol 2:

  1. Protocol 2
复制代码

添加新用户 SSH 访问权限:

  1. AllowUsers username #多用户空格隔开,DenyUsers即禁止访问用户
复制代码

加速SSH登入禁用UseDNS

  1. UseDNS no
复制代码

保存退出,并重启ssh

  1. reload ssh
复制代码

不要退出当前链接,用新建用户和端口登入,若没法登入,请检查ssh配置文件是否出错。


参考文章:


二,安装lnmp

lnmp是一系列的开源软件所组成的服务器环境安装包,取自linux,nginx,mysql和php四个单词的首字母。曾经试用过军哥的lnmp一键安装包,安装简单,配置也简单。不过我这种强迫症不喜欢现成的,说实话在这块鼓捣了很久。由于我一直搞不明白nginx的配置。


安装mysql:


  1. sudo apt-get install mysql-server
复制代码
安装过程当中会要求输入root密码,输入便可。安装完成后执行
  1. sudo mysql_secure_installation
复制代码
按提示操做便可。建议禁止root远程登入。


安装nginx:


Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,由一家俄罗斯公司开发。具体请百度百科。
  1. sudo apt-get install nginx
复制代码


安装php:
  1. sudo apt-get install php5-fpm php5-mysql
复制代码
至此全部安装完成


启动nginx:
  1. sudo service nginx start
复制代码
这一步若提示[emerg] bind() to 0.0.0.0:80 failed (98:address already in use ),通常是80端口被apache占用所致,杀死全部apache进程:
  1. sudo killall apache2
复制代码
关闭apache的开机启动:
  1. sudo update-rc.d -f apache2 remove
复制代码
在浏览器里访问你的IP(本地虚拟机中则是127.0.0.1),出现Welcome to Nginx,则说明nginx启动成功。


nginx配置:
nginx的配置文件在/etc/nginx/nginx.conf,具体设置请参考 Nginx战斗准备 —— 优化指南。注意到这个其中的两行:
  1. include /etc/nginx/conf.d/*.conf;
  2. include /etc/nginx/sites-enabled/;
复制代码
nginx下的一个虚拟主机就至关于一个网站,每一个虚拟主机的配置文件保存在上面两条路径。为了便于管理,我都是在/etc/nginx/conf.d/下新建conf配置文件。打开nginx的默认配置文件,修改使其支持php:
  1. sudo nano /etc/nginx/sites-enable/default
复制代码
找到server模块,按下修改:
  1. root /usr/share/nginx/www;#网站根目录
  2. index index.php index.html index.htm;
  3. server_name your_IP_address;
复制代码
往下找到location ~ .php$ ,去掉部分注释
  1. location ~ .php$ {
  2.                 fastcgi_split_path_info ^(.+.php)(/.+)$;
  3.         #        # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini
  4.         #
  5.         #        # With php5-cgi alone:
  6.         #        fastcgi_pass 127.0.0.1:9000;
  7.         #        # With php5-fpm:
  8.                 fastcgi_pass unix:/var/run/php5-fpm.sock;
  9.                 fastcgi_index index.php;
  10.                 include fastcgi_params;
  11.         }
复制代码
保存修改退出,并重启nginx:
  1. sudo service nginx restart
复制代码
新建一个phpinfo.php:
  1. sudo nano /usr/share/nginx/www/phpinfo.php
复制代码
输入:
  1. <;?php phpinfo(); ?>;
复制代码
保存退出,浏览器访问ipaddress/phpinfo.php,能正常显示php5-fpm的配置信息说明lnmp环境就搭好了。


建议安装phpmyadmin;
  1. sudo apt-get install phpmyadmin
  2. sudo ln -s /usr/share/phpmyadmin/ /usr/share/nginx/www 
  3. sudo service nginx reatsrt
复制代码
安装过程当中会提示输入mysql密码和设置root登陆密码,安装完成访问ip-address/phpmyadmin,在本地虚拟机中的,就是 http://127.0.0.1/phpmyadmin,进行管理数据库,


新建一个虚拟主机(添加网站):
复制/etc/nginx/sites-enable/default到/etc/nginx/conf.d/example.conf:
  1. sudo cp /etc/nginx/sites-enable/default /etc/nginx/conf.d/example.conf
复制代码

 


三,lnmp下安装wordpress
固然能够用其余blog程序,好比国产的typecho,不过wordpress更易于食用。
 
下载最新版wordpress
仍是下载中文版wordpress吧
把3.8.1改为最新的番号,详见https://cn.wordpress.org/releases/#latest
  1. wegt <a href="http://cn.wordpress.org/wordpress-3.8.1-zh_CN.tar.gz" target="_blank">http://cn.wordpress.org/wordpress-3.8.1-zh_CN.tar.gz</a>
复制代码
解压:
  1. tar -zxvf wordpress*.gz
复制代码
把解压出来的wordpress文件夹移到某个你想放的地方,我的随意。


建立数据库
装过phpmyadmin的,此时只要进phpmyadmin页面建立一个名为wordpress的数据库就好,其余默认。不然,进mysql建立吧。进入mysql:
  1. mysql -u root -p
复制代码
建立一个名为wordpress的数据库:
  1. create database wordpress;
复制代码
之后要是想修改wordpress数据库里的内容:
  1. use wordpress;
复制代码
这里涉及到mysql命令语句,有兴趣的能够研究一下,否则装个phpmyadmin吧。


安装wordpress
为了安全考虑,修改下web根目录的权限。我习惯直接将解压出来的wordpress目录看成网站的跟目录。
  1. sudo chown www-data:www-data * -R 
  2. sudo usermod -a -G www-data username
复制代码
www-data是ngimx的默认运行用户。
建立wordpress的nginx配置文件:
  1. sudo nano /etc/nginx/conf.d/wordpress.conf
复制代码
把下面这段扔进去:
  1. server {
  2.         listen 80 ;#default_server;
  3.         #listen [::]:80 default_server ipv6only=on;
  4.         root 这里写网站根目录;
  5.         index index.php index.html index.htm;
  6.         # Make site accessible from http://localhost/
  7.         server_name 127.0.0.10;#换成本身的域名或者IP
  8.         location / {
  9.                 #try_files $uri $uri/ =404;               
  10.         try_files $uri $uri/ /index.php?q=$uri&$args;#伪静态
  11.         }
  12.         error_page 404 /404.html;
  13.         error_page 500 502 503 504 /50x.html;
  14.         location = /50x.html {
  15.                 root /usr/share/nginx/html;
  16.         }
  17.         location ~ \.php$ {
  18.                 fastcgi_split_path_info ^(.+\.php)(/.+)$;
  19.                 fastcgi_pass unix:/var/run/php5-fpm.sock;
  20.                 fastcgi_index index.php;
  21.                 include fastcgi_params;
  22.         }
  23. }
复制代码
直接将/etc/nginx/sites-available/default里的内容复制进去也能够:
  1. sudo cp /etc/nginx/sites-available/default  /etc/nginx/conf.d/wordpress.conf
复制代码
关于wordpress的伪静态规则,上面一种,是wordpress官方给的,网上还能够搜到的比较多见的:
  1. location / {
  2. if (-f $request_filename/index.html){
  3.                 rewrite (.*) $1/index.html break;
  4.         }
  5. if (-f $request_filename/index.php){
  6.                 rewrite (.*) $1/index.php;
  7.         }
  8. if (!-f $request_filename){
  9.                 rewrite (.*) /index.php;
  10.         }
  11. }
复制代码
最好把 /etc/nginx/sites-available/default和/etc/nginx/sites-enabled/default下的配置文件删掉,否则容易出现问题。以后重启nginx:
  1. rm /etc/nginx/sites-available/default/* /etc/nginx/sites-enabled/defaul/*
复制代码
  1. sudo service nginx restart
复制代码

 

在浏览器输入ip或者域名
相关文章
相关标签/搜索