create_v3_wp_template.sh 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. #!/bin/bash
  2. #### Create V3 WP template site
  3. #### v3 自动基于临时站创建对应的模板站
  4. #### Author: chenpeiqing
  5. #### Date: 2025-03-13
  6. #### Usage: sh create_v3_wp_template.sh [临时站code] [模板站code]
  7. #### 示例: sh create_v3_wp_template.sh 2408210vakv9 2408210vakv9tp
  8. TEMP_CODE=$1
  9. TP_CODE=$2
  10. TEMPLATE_DOMAIN='v3.sohoeb2b.com'
  11. RDS_HOST='127.0.0.1'
  12. RDS_ADMIN='root'
  13. RDS_PWD='Initial0_123'
  14. OLD_DOMAIN_NAME=$TEMP_CODE.$TEMPLATE_DOMAIN
  15. DOMAIN_NAME=$TP_CODE.$TEMPLATE_DOMAIN
  16. #创建站点目录
  17. mkdir /usr/local/wwwtemplate/$TP_CODE
  18. #打包模板站包
  19. cd /usr/local/wwwroot/$TEMP_CODE
  20. tar -czf $TEMP_CODE.tar.gz *
  21. sudo mv $TEMP_CODE.tar.gz /usr/local/wwwtemplate/$TP_CODE
  22. #下载模板站数据库
  23. mysqldump --user=$RDS_ADMIN --password=$RDS_PWD --host=localhost --port=3306 --no-create-db --default-character-set=utf8 $TEMP_CODE > /opt/adweb3/temp_package/$TEMP_CODE.sql
  24. echo '解压模板站开始'
  25. cd /usr/local/wwwtemplate/$TP_CODE
  26. tar -xzf $TEMP_CODE.tar.gz
  27. echo "解压模板站结束,共计花费:"$((end_time - start_time))"s"
  28. #更新数据库连接配置
  29. echo "修改站点【"$TP_CODE"】wp-config.php配置"
  30. start_time=$(date +'%s')
  31. #sed -i "s:root:adweb:g" /usr/local/wwwtemplate/$TP_CODE/wp-config.php
  32. #sed -i "s:Initial0_123:2024_RqBQxctjakHCJVq8kmmYHQKZQGU4YMUH:g" /usr/local/wwwtemplate/$TP_CODE/wp-config.php
  33. sed -i "s:$TEMP_CODE:$TP_CODE:g" /usr/local/wwwtemplate/$TP_CODE/wp-config.php
  34. sed -i "s:FILE_NAME:$TP_CODE:g" /usr/local/wwwtemplate/$TP_CODE/domain.txt
  35. sed -i "s:'$TEMP_CODE':'$TP_CODE':g" /usr/local/wwwtemplate/$TP_CODE/wp-config.php
  36. end_time=$(date +'%s')
  37. echo "修改站点【"$TP_CODE"】wp-config.php配置修改完成,共计花费:"$((end_time - start_time))"s"
  38. #创建数据库,赋权
  39. echo '创建数据库开始:'
  40. start_time=$(date +'%s')
  41. mysql -h$RDS_HOST -u$RDS_ADMIN -p$RDS_PWD<< EOF
  42. DROP DATABASE IF EXISTS $TP_CODE;
  43. CREATE DATABASE $TP_CODE CHARACTER SET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  44. GRANT ALL ON $TP_CODE.* TO 'adweb'@'localhost';
  45. FLUSH PRIVILEGES;
  46. exit
  47. EOF
  48. end_time=$(date +'%s')
  49. echo "创建数据库花费:"$((end_time - start_time))"s"
  50. #导入数据库
  51. echo '导入数据库开始:'
  52. start_time=$(date +'%s')
  53. mysql -u$RDS_ADMIN -p$RDS_PWD $TP_CODE < /opt/adweb3/temp_package/$TP_CODE.sql
  54. end_time=$(date +'%s')
  55. echo "【"$FILE_NAME"】网站导入数据库完成,共计花费:"$((end_time - start_time))"s"
  56. #nginx
  57. echo '创建并更新新站点的nginx配置开始:'
  58. start_time=$(date +'%s')
  59. cp /opt/adweb3/nginx_template/wp-template.conf /usr/local/openresty/nginx/vhost/template/$TP_CODE.conf
  60. sed -i "s:SITE_CODE:$FILE_NAME:g" /usr/local/openresty/nginx/vhost/template/$TP_CODE.conf
  61. echo "开始重启nginx配置"
  62. /usr/local/openresty/nginx/sbin/nginx -s reload
  63. echo "nginx配置重启完成"echo "开始重启nginx配置"
  64. #更新新站点WP数据库中的域名并清空缓存
  65. echo '更新新站点WP数据库中的域名并清空缓存开始:'
  66. start_time=$(date +'%s')
  67. cd /usr/local/template/$TP_CODE
  68. cp /opt/adweb3/config/wp-cli.phar /usr/local/template/$TP_CODE
  69. php ./wp-cli.phar search-replace "$OLD_DOMAIN_NAME" "$DOMAIN_NAME" --allow-root
  70. php ./wp-cli.phar search-replace "http://$DOMAIN_NAME" "https://$DOMAIN_NAME" --allow-root
  71. php ./wp-cli.phar cache flush --allow-root
  72. rm -rf wp-cli.phar
  73. end_time=$(date +'%s')
  74. echo "更新新站点WP数据库中的域名并清空缓存花费:"$((end_time - start_time))"s"
  75. echo "清空老站点缓存开始:"
  76. start_time=$(date +'%s')
  77. cp /opt/adweb3/config/wp-cli.phar /usr/local/wwwroot/$TEMP_CODE
  78. cd /usr/local/wwwroot/$TEMP_CODE
  79. php ./wp-cli.phar cache flush --allow-root
  80. rm -rf wp-cli.phar
  81. end_time=$(date +'%s')
  82. echo "清空模板站点缓存花费:"$((end_time - start_time))"s"
  83. end_time=$(date +'%s')
  84. echo "本次拉取临时站点共计花费: "$((end_time - first_time))"s"
  85. #更新目录权限组
  86. cd /usr/local/template
  87. chown -R www-data:www-data $TP_CODE