0,最好先查看系统版本,再去找对应版本的相关教程
cat /etc/redhat-release 查看CentOS版本
1,安装nginx
sudo yum install epel-release -y
安装仓库
sudo yum install https://centos7.iuscommunity.org/ius-release.rpm -y
查看仓库里的nginx版本
yum list nginx*
安装nginx
sudo yum install nginx
开机自启动
sudo systemctl enable nginx
启动
sudo systemctl start nginx
重新载入配置
nginx -s reload
service nginx restart 重启
service nginx stop 停止
service nginx start 启动
修改/etc/nginx/conf/nginx.conf
user nginx;
worker_processes 4;#CPU内核数
worker_cpu_affinity 0001 0010 0100 1000;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
worker_rlimit_nofile 65535;
events {
use epoll;
worker_connections 65535;
}
http {
include /etc/nginx/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"';
access_log /var/log/nginx/access.log main;
sendfile on;
#tcp_nopush on;
keepalive_timeout 650;
types_hash_max_size 2048;
fastcgi_connect_timeout 300;
fastcgi_send_timeout 300;
fastcgi_read_timeout 300;
client_max_body_size 5m;
#gzip on;
include /etc/nginx/conf.d/*.conf;
#隐藏版本号
server_tokens off;
}
站点配置
#非www域名301跳转到www域名
server {
listen 80;
listen 443;
server_name site.com;
return 301 http://www.site.com$request_uri;
}
server {
listen 80;
listen 443;
server_name www.site.com;
root /data/site.com/;
index index.php index.html;
charset utf-8;
#日志按日期分割
if ($time_iso8601 ~ "(\d{4})-(\d{2})-(\d{2})") { set $time $1$2$3; }
access_log /var/log/nginx/access_www.site.com_${time}.log;
error_log /var/log/nginx/error_www.site.com_${time}.log;
location = /robots.txt { allow all; access_log off; log_not_found off; }
location = /favicon.ico { allow all; access_log off; log_not_found off; }
error_page 401 /401.html;
error_page 403 /403.html;
error_page 404 /404.html;
error_page 500 502 503 504 /50x.html;
location /
{
#CI框架去掉index.php
if (!-e $request_filename) {
rewrite ^/(.*)$ /index.php/$1 last;
break;
}
}
location ~ .*\.(php|php5)?($|/)
{
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_split_path_info ^(.+\.php)(.*)$;
fastcgi_param PATH_INFO $fastcgi_path_info;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
location ~ /\.ht {
deny all;
}
}
2,安装php5.6
切换源
rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
查看仓库里的php版本
yum list php56w*
sudo yum -y install php56w php56w-mysql php56w-gd libjpeg* php56w-ldap php56w-odbc php56w-pear php56w-xml php56w-xmlrpc php56w-mbstring php56w-bcmath
sudo yum -y install httpd php-gd56w php-intl56w php-mysql56w mod_ssl openssl mcrypt php5-mcrypt56w
sudo yum -y install php56w-mcrypt php56w-soap php56w-intl php56w-pdo
sudo yum -y install php56w-gd php56w-mysqlnd php56w-pdo php56w-mcrypt php56w-mbstring php56w-json php56w-opcache php56w-xml
sudo yum -y install php56w-fpm
开机自启动
sudo systemctl enable php-fpm
启动
sudo systemctl start php-fpm
停止PHP
pkill php-fpm
重启PHP的
service php-fpm restart
找到php.ini文件
find / -name php.ini
修改php.ini文件配置
a,修改expose_php = On为expose_php = Off,功能为隐藏response里的php语言和版本的显示,提高安全性
b,修改memory_limit = 128M为想要的内存限制
c,修改post_max_size = 3M为想要的最大post长度
d,修改upload_max_filesize = 6M为想要的最大upload长度
找到php-fpm的www.conf文件
find / -name www.conf
修改www.conf文件配置
a,修改user = nginx
a,修改group = nginx
安装PHP7.4
查看仓库里的php版本
yum list |grep php74
如果仓库里没有php7.4
安装源
yum install epel-release
yum install http://rpms.remirepo.net/enterprise/remi-release-7.rpm
安装管理工具
yum install yum-utils
安装
yum -y install php74 php74-php-fpm php74-php-json php74-php-mysqlnd php74-php-gd php74-php-pecl-zip php74-php-xml php74-php-cli php74-php-intl php74-php-redis php74-php-devel php74-php-mcrypt php74-php-soap php74-php-pdo php74-php-mbstring php74-php-curl php74-php-pear php74-php-bcmath php74-php-ldap php74-php-odbc php74-php-xmlrpc php74-php-opcache php74-php-calendar php74-php-sockets php74-php-session php74-php-snmp mod_ssl openssl httpd zlib libxml libjpeg freetype libpng libiconv zlib-devel libxml2 libxml2-devel libjpeg-devel freetype-devel libpng-devel gd-devel curl-devel openssl-devel libxslt-deve
查看php版本
php -v
如果查看php版本没有
设置环境变量
export PATH="/opt/remi/php74/root/usr/bin:$PATH"
开机自启动
sudo systemctl enable php74-php-fpm
启动
sudo systemctl start php74-php-fpm
3,安装mysql
切换源
wget -i -c http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm
yum -y install mysql57-community-release-el7-10.noarch.rpm
直接安装MySQL可能会出现这个错误
Public key for mysql-community-client-5.7.40-1.el7.x86_64.rpm is not installed
最好先执行
Public key for mysql-community-client-5.7.40-1.el7.x86_64.rpm is not installed
安装MySQL服务器
yum install mysql-community-server
启动MySQL
systemctl start mysqld.service
开机自启
sudo systemctl enable mysqld.service
查看MySQL运行状态
systemctl status mysqld.service
此时MySQL已经开始正常运行,需要找出root的密码
grep "password" /var/log/mysqld.log
输入初始密码,此时不能做任何事情,因为MYSQL默认必须修改密码才能正常使用
ALTER USER 'root'@'localhost' IDENTIFIED BY 'new password';
可通过如下命令查看完整的初始密码规则
show variables like 'validate_password';
可通过如下命令修改
set global validate_password_policy=0;
set global validate_password_length=1;
还有一个问题就是Yum Repository,以后每次 yum 操作都会自动更新,需要把这个卸载掉
yum -y remove mysql57-community-release-el7-10.noarch
登录mysql
mysql -h 主机 -P 端口 -u 用户名 -p
导出数据库.gz格式
mysqldump -hlocalhost -P3306 -u用户名 -p密码 数据库名 |gzip >文件名.sql.gz
导入.gz格式数据库
gunzip < /data/文件名.gz | mysql -u用户名 -p密码 数据库名
4,安装redis
查看仓库里的redis版本
yum list | grep redis
安装
yum install redis
查看redis的配置文件
whereis redis
查看redis的相关执行文件路径
which is redis
修改密码在redis.conf中修改。找到requirepass 把后面的密码改掉。
重启
systemctl start redis.service
设置redis服务器端开机自启(只需要设置一次即可)
systemctl enable(disable则为取消) redis.service
其他相关操作
systemctl status(查看运行状态)、stop(停止运行) redis.service
5,安装SVN
安装
yum install subversion
创建SVN主目录
mkdir -p /svndata
创建SVN分目录
mkdir -p /svndata/project1
svnadmin create /svndata/project1
svnadmin create /svndata/project2
svnadmin create /svndata/project3
...
创建完之后,/svndata/project1目录下会生成conf文件夹
修改authz文件:
[groups]
group1 = harry,sally,&joe
[/]
@group1 = rw
* =
修改passwd文件:
[users]
harry = harryssecret
将authz文件和passwd文件移动到SVN主目录/svndata下
只保留svnserve.conf文件并修改:
anon-access = none
auth-access = write
password-db = ../../conf/passwd
authz-db = ../../conf/authz
启动SVN,后边可以修改端口号
svnserve -d -r "/svndata" --listen-port 8443
停止SVN
killall svnserve
SVN服务器路径为:
svn://IP地址:8443/project1/
如果要设置服务器文件自动更新到站点,则要先迁出到服务器
svn checkout svn://IP地址:8443/project1/ /data/project1/
设置钩子文件
/svndata/project1/hooks/目录新建post-commit文件,并设置777权限,很重要
#!/bin/sh
export LANG=en_US.UTF-8
SVN_PATH=/usr/bin/svn
WEB_PATH=/data/project1/
$SVN_PATH update $WEB_PATH --username 用户名 --password 密码
更新文件:
svn update
清理:
svn cleanup
要先cd到站点目录