在亚马逊云主机搭建环境 准备工作,下好所需的包
mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz
nginx-1.12.1.tar.gz php-5.6.30.tar.bz2
安装msyql
解压mysql
mysql 是二进制免编译包,所以省去的编译的过程
移动到/usr/local/下,更名为mysql
tar -zxvf mysql-5.6.35-linux-glibc2.5-x86_64.tar.g
mv mysql-5.6.35-linux-glibc2.5-x86_64 /usr/local/mysql
初始化
进入所在目录进行
cd /usr/local/mysql
初始化前,记得确定是否有data目录
./scripts/mysql_install_db --user=mysql --datadir=/data/mysql
安装缺少的依赖包,否则不能成功初始化
yum install -y perl-Data-Dumper.x86_64
yum install -y libaio
都是在mysql目录下进行的
拷贝配置文件
cp support-files/my-default.cnf /etc/my.cnf
拷贝启动脚本
cp support-files/mysql.server /etc/init.d/mysqld
更改配置文件
vim /etc/my.cnf
在[mysqld] 下 增加
datadir=/data/mysql
socket=/tmp/mysql.sock
更改启动脚本
vim /etc/init.d/mysqld
找到下面两个项,添加上路径
basedir=/usr/local/mysql
datadir=/data/mysql
检查开启服务
/etc/init.d/mysqld start
屏幕输出
Starting MySQL.Logging to '/data/mysql/ip-172-31-45-37.us-east-2.compute.internal.err'.
SUCCESS!
将mysql 加入到服务列表
chkconfig --add mysqld
配置mysql服务,开机启动
chkconfig mysqld on
安装php-fpm
安装依赖包
yum install -y gcc
yum install -y libxml2-devel.x86_64
yum install -y openssl-devel.x86_64
yum install -y bzip2-devel.x86_64
yum install -y libjpeg-devel
yum install -y libpng-devel
yum install -y freetype-devel
yum install -y libcurl-devel.x86_64
安装第三方yum源 //因为是亚马逊的主机不支持安装拓展源,使用安装第三方源
wget http://www.atomicorp.com/installers/atomic
sh atomic
yum install php-mcrypt libmcrypt libmcrypt-devel
初始化
./configure --prefix=/usr/local/php-fpm
--with-config-file-path=/usr/local/php-fpm/etc
--enable-fpm
--with-fpm-user=php-fpm
--with-fpm-group=php-fpm
--with-mysql=/usr/local/mysql
--with-mysqli=/usr/local/mysql/bin/mysql_config
--with-pdo-mysql=/usr/local/mysql
--with-mysql-sock=/tmp/mysql.sock
--with-libxml-dir
--with-gd
--with-jpeg-dir
--with-png-dir
--with-freetype-dir
--with-iconv-dir
--with-zlib-dir
--with-mcrypt
--enable-soap
--enable-gd-native-ttf
--enable-ftp
--enable-mbstring
--enable-exif
--with-pear
--with-curl
--with-openssl
--disable-fileinfo //编译错误之后新加入
编译
make && make install
出错
make: *** [ext/fileinfo/libmagic/apprentice.lo] Error 1
当配置PHP时出现 make: *** [ext/fileinfo/libmagic/apprentice.lo] Error 1 时
是因为服务器内存不足1G。
只需要在配置命令中添加 --disable-fileinfo即可
拷贝主配置文件
cp php.ini-production /usr/local/php-fpm/etc/php.ini
新增配置文件
vim /usr/local/php-fpm/etc/php-fpm.con
[global]
pid = /usr/local/php-fpm/var/run/php-fpm.pid
error_log = /usr/local/php-fpm/var/log/php-fpm.log
include = etc/php-fpm.d/*.conf //可以自定义pool
拷贝启动脚本
cp /usr/local/src/php-5.6.30/sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm
将php-fpm加入到服务列表里
chkconfig --add php-fpm
配置开机启动php-fpm
chkconfig php-fpm on
开启服务器
service php-fpm start
查看进程,服务是否开启
ps aux |grep php-fpm
Nginx安装
./configure --prefix=/usr/local/nginx
给Nginx创建启动脚本
vim /etc/init.d/nginx
#!/bin/bash
# chkconfig: - 30 21
# description: http service.
# Source Function Library
. /etc/init.d/functions
# Nginx Settings
NGINX_SBIN="/usr/local/nginx/sbin/nginx"
NGINX_CONF="/usr/local/nginx/conf/nginx.conf"
NGINX_PID="/usr/local/nginx/logs/nginx.pid"
RETVAL=0
prog="Nginx"
start()
{
echo -n $"Starting $prog: "
mkdir -p /dev/shm/nginx_temp
daemon $NGINX_SBIN -c $NGINX_CONF
RETVAL=$?
echo
return $RETVAL
}
stop()
{
echo -n $"Stopping $prog: "
killproc -p $NGINX_PID $NGINX_SBIN -TERM
rm -rf /dev/shm/nginx_temp
RETVAL=$?
echo
return $RETVAL
}
reload()
{
echo -n $"Reloading $prog: "
killproc -p $NGINX_PID $NGINX_SBIN -HUP
RETVAL=$?
echo
return $RETVAL
}
restart()
{
stop
start
}
configtest()
{
$NGINX_SBIN -c $NGINX_CONF -t
return 0
}
case "$1" in
start)
start
;;
stop)
stop
;;
reload)
reload
;;
restart)
restart
;;
configtest)
configtest
;;
*)
echo $"Usage: $0 {start|stop|reload|restart|configtest}"
RETVAL=1
esac
exit $RETVAL
自定义 nginx.conf文件
user nobody nobody;
worker_processes 2;
error_log /usr/local/nginx/logs/nginx_error.log crit;
pid /usr/local/nginx/logs/nginx.pid;
worker_rlimit_nofile 51200;
events
{
use epoll;
worker_connections 6000;
}
http
{
include mime.types;
default_type application/octet-stream;
server_names_hash_bucket_size 3526;
server_names_hash_max_size 4096;
log_format combined_realip '$remote_addr $http_x_forwarded_for [$time_local]'
' $host "$request_uri" $status'
' "$http_referer" "$http_user_agent"';
sendfile on;
tcp_nopush on;
keepalive_timeout 30;
client_header_timeout 3m;
client_body_timeout 3m;
send_timeout 3m;
connection_pool_size 256;
client_header_buffer_size 1k;
large_client_header_buffers 8 4k;
request_pool_size 4k;
output_buffers 4 32k;
postpone_output 1460;
client_max_body_size 10m;
client_body_buffer_size 256k;
client_body_temp_path /usr/local/nginx/client_body_temp;
proxy_temp_path /usr/local/nginx/proxy_temp;
fastcgi_temp_path /usr/local/nginx/fastcgi_temp;
fastcgi_intercept_errors on;
tcp_nodelay on;
gzip on;
gzip_min_length 1k;
gzip_buffers 4 8k;
gzip_comp_level 5;
gzip_http_version 1.1;
gzip_types text/plain application/x-javascript text/css text/htm
application/xml;
include vhost/*.conf; //新增这一行,定义默认虚拟主机的目录
}
检查一下是否存在语法问题
/usr/local/nginx/sbin/nginx -t
重启服务
/usr/local/nginx/sbin/nginx -s reload
报错:
nginx: [error] invalid PID number "" in "/usr/local/nginx/logs/nginx.pid"
原来服务器没有启动
service nginx start
更改配置文件权限
chmod 755 /etc/init.d/nginx
将nginx加入到服务列表里
chkconfig --add nginx
配置开启启动nginx服务
chkconfig nginx on
搭建 blog、cms、bbs
下好所需文件
解压,丢解压好的包到/data/wwwroot/目录
为了保证访问,给目录权限
chmod 755 /data/wwwroot/
blog 《Typecho》
配置vhost
vim /usr/local/nginx/conf/vhost/build.conf
内容如下:
server
{
listen 80 ;
server_name blog.in-86.com;
index index.html index.htm index.php;
root /data/wwwroot/build;
access_log /tmp/build.com.log combined_realip; //访问日志
if (!-e $request_filename) {
rewrite ^(.*)$ /index.php$1 last;
}
location ~ \.php(\/.*)*$
{
set $path_info "";
set $real_script_name $fastcgi_script_name;
if ($fastcgi_script_name ~ "^(.+?\.php)(/.+)$") {
set $real_script_name $1;
set $path_info $2;
}
fastcgi_param SCRIPT_FILENAME $document_root$real_script_name;
fastcgi_param SCRIPT_NAME $real_script_name;
fastcgi_param PATH_INFO $path_info;
include fastcgi_params;
fastcgi_pass unix:/tmp/php-fcgi.sock;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /data/wwwroot/build$fastcgi_script_name;
}
}
高亮为 Typecho 这个程序的必要配置,如不这样配置会导致管理内页访问404
创建pool配置文件
vim /usr/local/php-fpm/etc/php-fpm.d/blog.conf
内容如下:
[blog]
listen = /tmp/php-fcgi.sock
listen.mode = 666
user = php-fpm
group = php-fpm
pm = dynamic
pm.max_children = 50
pm.start_servers = 20
pm.min_spare_servers = 5
pm.max_spare_servers = 35
pm.max_requests = 500
rlimit_files = 1024
配置好记得检查语法,重新加载服务
nginx
/usr/local/nginx/sbin/nginx -t
/usr/local/nginx/sbin/nginx -s reload
php-fpm
/usr/local/php-fpm/sbin/php-fpm -t
/etc/init.d/php-fpm reload
关闭selinux防火墙
getenforce //检查防火墙状态
setenforce 0 //临时关闭
vim /etc/selinux/config //改配置文件永久关闭
检查iptables
iptables -F
iptables -I INPUT -p tcp --dport 80 -j ACCEP //放行80
iptables -nvL //查看规则
netstat -lntp //查看nginx是否开始监听80端口
检查是否通
curl -x127.0.0.1:80 blog.in-86.com -I
出错:
curl 返回码200,证明本地访问没有问题,但是浏览器访问不到
检查了80端口的连通性
Windows
telnet 主机IP 80
发现80端口不通的,多次检查,才发现域名解析的主机名错了;调整解析的主机名以后,就能正常访问了。
浏览器安装Typecho 再次出现问题。mysql不能进入,不然就进入了创建不了数据库 方法操作很简单,如下:
# /etc/init.d/mysqld stop //停止MySQL服务的运行
# mysqld_safe --user=mysql --skip-grant-tables --skip-networking & //跳过受权表访问
# mysql -u root mysql //登录mysql
在mysql5.7以下的版本如下:
mysql> UPDATE user SET Password=PASSWORD('newpassword') where USER='root' and host='127.0.0.1' or host='localhost'; //把空的用户密码都修改成非空的密码就行了。
在mysql5.7版本如下:
update mysql.user set authentication_string=password('newpassword') where user='root' and host='127.0.0.1' or host='localhost';
mysql> FLUSH PRIVILEGES;
mysql> quit # /etc/init.d/mysqld restart //离开并重启mysql
# mysql -uroot -p
Enter password: <输入新设的密码newpassword>
这时就能正常进入了
mysql -uroot -p //登录
create database typecho; //创建数据库
grant all on *.* to root@127.0.0.1 identified by 'newpassword';
然后就可以成功的配置 安装Typecho
重Typecho的安装步骤,即可完成discuz、dedecms的安装(mysql除外)数据库统一使用root 密码 newpassword
安装discuz的需要对几个特殊的目录给予写的权限,在解压好所有文件的时候,我就直接执行的chmod 755 -R ,所有就省去了这个步骤(因为是测试,权限的不是特别重要)