欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

在Ubuntu 14.04上部署 PHP 环境及 WordPress

程序员文章站 2023-11-16 13:52:10
软件及版本选择 ubuntu 14.04 ubuntu 是目前用户数量数一数二的发行版,背后有大土豪维护,可以说是轻量级用户的最佳选择。而 14.04 是目前最新的 l...

软件及版本选择

ubuntu 14.04

ubuntu 是目前用户数量数一数二的发行版,背后有大土豪维护,可以说是轻量级用户的最佳选择。而 14.04 是目前最新的 lts 版本,目前已经发布了半年了,基本是目前支持最好的版本。

nginx

nginx 是一个轻量级的,配置灵活,擅长并发的 web 服务器。

php-fpm

php-fpm 是目前官方推荐的最佳的运行模式。

mariadb

mysql 的替代品,毕竟目前 mysql 的创始人已经不建议我们使用 mysql 了。

基本配置

通常当你创建了一台 vps, 你会得到一个 ip 和一个 root 密码,所以,先用 ssh 登上你的服务器:

ssh root@106.186.21.33

# 如果有警告输入 yes 来确认,然后输入你的 root 密码
配置一下公钥登录,省着每次登录都要输入密码,非常建议像我一样把公钥上传到一个公开的地址,这样只要一条命令就可以设置好:

mkdir ~/.ssh; curl 'https://raw.githubusercontent.com/jysperm/meta/master/key/jyair.pub' >> ~/.ssh/authorized_keys; chmod -r 700 ~/.ssh;

然后更新一下软件包列表,升级现有软件包:

apt-get update
apt-get upgrade

修改一下主机名,最好改成一个确实可以访问到这台服务器的域名:

vi /etc/hostname
vi /etc/hosts

安装软件包

apt-get install nginx postfix php5-fpm mariadb-server memcached
apt-get install php-pear php5-mysql php5-curl php5-gd php5-mcrypt php5-memcache
apt-get install python make screen git wget zip unzip iftop vim curl htop iptraf nethogs
nginx: web 服务器
postfix: smtp 服务器,用来支持从本地发送邮件
php5-fpm: php 进程管理器,及 php 解释器
mariadb-server: 类 mysql 数据库
memcached: 基于内存的缓存,很多程序会用到
php-pear: php 的包管理器
php5-mysql: php mysql 数据库驱动
php5-curl: 一个 http 协议库
php5-gd: 一个图像处理库
php5-mcrypt: 一个加密算法库
php5-memcache: memcached 驱动
python: 一个常用的脚本语言解释器
make: 一个常用的构建工具
screen: 一个常用的 shell 会话管理工具
git: 一个常用的版本控制工具
wget, curl: 常用的文件下载工具
zip, unzip: zip 压缩和解压工具
iftop, iptraf, nethogs: 常用的流量监控工具
vim: 一个常用的编辑器
htop: 一个常用的进程监控工具

安装 wordpress

新建一个普通用户,并切换到该用户

adduser wordpress
su wordpress
cd ~

下载 wordpress, 请自行到官网查看最新版本的下载地址:

wget http://cn.wordpress.org/wordpress-3.9-zh_cn.zip

解压文件:

unzip wordpress-*.zip


设置文件权限:

chmod -r 750 wordpress


删除安装包:

rm wordpress-*.zip


回到 root:

exit


配置 php-fpm

为 wordpress 创建一个进程池:

vi /etc/php5/fpm/pool.d/wordpress.conf


这是一份很典型的配置文件,通过监听 unix socket 来提供服务,动态调节进程数,最高 10 个进程,最低 3 个进程:

[wordpress]

user = wordpress
group = wordpress

listen = /home/wordpress/phpfpm.sock

listen.owner = wordpress
listen.group = wordpress
listen.mode = 0660

pm = dynamic
pm.max_children = 10
pm.min_spare_servers = 3
pm.max_spare_servers = 5

slowlog = /home/wordpress/phpfpm.slowlog
request_slowlog_timeout = 5s
request_terminate_timeout = 15s

php_admin_value[error_log] = /home/wordpress/phpfpm_error.log
php_admin_flag[log_errors] = on

配置 nginx

删掉 nginx 的默认站点:

rm /etc/nginx/sites-enabled/default


新建一个站点:

vi /etc/nginx/sites-enabled/wordpress

这份配置文件已将请求重写到 index.php, 可以直接在 wordpress 中使用「固定链接」功能:

server {
  listen 80;
  server_name jysperm.me;

  root /home/wordpress/wordpress;
  index index.html index.php;
  autoindex off;

  location / {
    try_files $uri $uri/ /index.php;
  } 

  location ~ \.php$ { 
    fastcgi_pass unix:///home/wordpress/phpfpm.sock;
    include fastcgi_params;
    fastcgi_index index.php;
  }
}

如果你希望把其他所有域名都跳转到你的站点,可以添加这么一段:

server {
  listen 80 default_server;
  listen [::]:80 default_server ipv6only=on;
  rewrite ^/(.*)$ http://jysperm.me permanent;
}


然后我们需要修正 nginx 和 php-fpm 配合的一个 bug:

vi /etc/nginx/fastcgi_params


将 fastcgi_param script_filename 开头的行改为:

fastcgi_param script_filename $document_root$fastcgi_script_name;


为 nginx 添加读取 wordpress 文件的权限:

usermod -g wordpress -a www-data


配置 mysql

进入 mysql 控制台:

mysql -p


# 需要输入你的 mysql root 密码

# 创建数据库

create database `wordpress`;

# 为 wordpress 新建用户

create user 'wordpress'@'localhost' identified by 'password';

# 授予权限

grant all privileges on `wordpress` . * to 'wordpress'@'localhost';

# 退出
quit
重启

好了,已经配置完成了,我们直接重启服务器即可,这样所有服务都会重启并使用新的配置:

reboot