Home  >  Article  >  Backend Development  >  How Alibaba Cloud builds a small program PHP environment

How Alibaba Cloud builds a small program PHP environment

小云云
小云云Original
2018-03-19 13:40:474011browse

Recently I was thinking about whether Alibaba Cloud can build an official demo of small programs. I have used a small program solution based on Tengxun Cloud before. Although it is very good, I have not registered a domain name with Tengxun Cloud. I have used it in Tengxun Cloud. A domain name has been registered on Alibaba Cloud. This article mainly shares with you how Alibaba Cloud builds a small program PHP environment. I hope it can help you.

Basic environment CentOS 7.3

(1) Install Nginx

yum -y install nginx

Check whether the installation is successful

nginx -v

If the installation is successful, it will display

(2) Install PHP

Wafer's Demo requires PHP version 5.6 or above, add remi source.

wget 'https://mirrors.tuna.tsinghua.edu.cn/remi/enterprise/remi.repo' -O /etc/yum.repos.d/remi.repo

Installation

yum install --enablerepo=remi --enablerepo=remi-php56 php php-mbstring php-mcrypt php-mysql php-curl php-fpm

Check whether the installation is successful

php -v

php version must be greater than 5.6

(3) Configure Nginx and HTTPS

Apply for an SSL certificate. You can go to Alibaba Cloud to apply for a free SSL certificate. After the application is successful, download the certificate and put the compressed package Upload the certificate file in the Nginx directory to the server's /data/release/nginx directory. If there is no such directory, create a new one: After uploading the certificate, configure Nginx, enter the server's /etc/nginx/conf.d directory, and create a new weapp .conf file, the content is as follows, please note (change www.xx.com to your own domain name, 1_www.xx.com_budle.crt and 2_www.xx.com.key to your own certificate files respectively)

# 重定向 http 到 https
www.xx.com

server { listen 80; server_name www.xx.com; rewrite ^(.*)$ https://$server_name$1 permanent;}server { listen 443; server_name www.xx.com; ssl on; ssl_certificate / data/release /nginx/1_www.xx.com_bundle.crt; ssl_certificate_key /data/release/nginx/2_www.xx.com.key; ssl_session_timeout 5m; ssl_protocols TLSv1 TLSv1.1 TLSv1.2 ; ssl_ciphers               ECDHE-RSA-AES256-GCM-SHA384: ECDHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-SHA384:ECDHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA:ECDHE-RSA-AES128- SHA:DHE-RSA-AES256-SHA:DHE-RSA-AES128-SHA; ssl_session_cache shared:SSL:50m; ssl_prefer_server_ciphers on; root /data/release/php-demo; location ~ \.php$ { root /data/release /php-demo; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } location /weapp/ { root /data/release/php-demo; index index.html index.htm index.php; try_files $uri $uri/ /index.php; }}

Run nginx

nginx -t

(4) Install mysql

Installation mysql5.7

1. Configure YUM source

# Download the mysql source installation package
wget http://dev.mysql.com/get/mysql57-community-release -el7-8.noarch.rpm

# Install mysql source
yum localinstall mysql57-community-release-el7-8.noarch.rpm

Check whether the mysql source is installed successfully
yum repolist enabled | grep "mysql.*-community.*"


2. Install MySQL
yum install mysql-community-server

3. Start the MySQL service
systemctl start mysqld

View the startup status of MySQL
shell> systemctl status mysqld


4. Start up
systemctl enable mysqld
systemctl daemon-reload

5. Modify the root local login password
After the mysql installation is completed, go to / A default password is generated for root in the var/log/mysqld.log file. Find the root default password in the following way, and then log in to mysql to modify it:
grep 'temporary password' /var/log/mysqld.log

Log in and modify the default password
mysql - u root -p

mysql>ALTER USER 'root'@'localhost' IDENTIFIED BY 'New password!';


Create a new database named cAuth, sorting rules It is utf8mb4_unicode_ci, the applet background uses
mysql>CREATE DATABASE IF NOT EXISTS cAuth, the sorting rule is DEFAULT CHARSET utf8mb4 COLLATE utf8mb4_unicode_ci;


(五)上传 Demo 和启动

到 wafer2-quickstart-php 仓库下载最新的 Demo 代码,修改 server/config.php:

<?php/**
 * Wafer php demo 配置文件
 */$config = [    &#39;rootPath&#39; => &#39;&#39;,    // 微信小程序 AppID
    &#39;appId&#39; => &#39;&#39;,    // 微信小程序 AppSecret
    &#39;appSecret&#39; => &#39;&#39;,    // 使用腾讯云代理登录  
    &#39;useQcloudLogin&#39; => false, //不使用腾迅云代理登录    /**
     * 这里请填写云数据库的
     */
    &#39;mysql&#39; => [        &#39;host&#39; => &#39;localhost&#39;,        &#39;port&#39; => 3306,        &#39;user&#39; => &#39;root&#39;,        &#39;db&#39;   => &#39;cAuth&#39;,        &#39;pass&#39; => &#39;数据库密码&#39;,        &#39;char&#39; => &#39;utf8mb4&#39;
    ],    &#39;cos&#39; => [        /**
         * 区域
         * 上海:cn-east
         * 广州:cn-sorth
         * 北京:cn-north
         * 广州二区:cn-south-2
         * 成都:cn-southwest
         * 新加坡:sg
         * @see https://cloud.tencent.com/document/product/436/6224
         */
        &#39;region&#39; => &#39;cn-sorth&#39;,        // Bucket 名称
        &#39;fileBucket&#39; => &#39;wafer&#39;,        // 文件夹
        &#39;uploadFolder&#39; => &#39;&#39;
    ],    // 微信登录态有效期
    &#39;wxLoginExpires&#39; => 7200,    &#39;wxMessageToken&#39; => &#39;abcdefgh&#39;,    // 其他配置
    &#39;serverHost&#39; => &#39;wx.wafersolution.com&#39;,    &#39;tunnelServerUrl&#39; => &#39;http://tunnel.ws.qcloud.la&#39;,    &#39;tunnelSignatureKey&#39; => &#39;27fb7d1c161b7ca52d73cce0f1d833f9f5b5ec89&#39;,      // 腾讯云相关配置可以查看云 API 秘钥控制台:https://console.cloud.tencent.com/capi
    &#39;qcloudAppId&#39; => 1200000000,// 必须是数字
    &#39;qcloudSecretId&#39; => &#39;你的腾讯云 SecretId&#39;,    &#39;qcloudSecretKey&#39; => &#39;你的腾讯云 SecretKey&#39;,    &#39;networkTimeout&#39; => 30000];

接着将 server 目录下的所有文件都上传到 /data/release/weapp/php-demo 目录下:

相关推荐:

linux下apache重启并查看php环境

PHP环境配置

LNMP环境搭建(一)搭建PHP环境

The above is the detailed content of How Alibaba Cloud builds a small program PHP environment. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn