zoukankan      html  css  js  c++  java
  • CentOS8最全源码安装 LAMP

    地址链接

    LNMP源码安装地址 https://www.cnblogs.com/xiao-chuan-/p/14124394.html

    码云 https://gitee.com/lqcjy/centos/tree/master/v8

    安装环境

    centos8-64位
    保证虚拟机内存4G及以上,内核数量为2及以上,硬盘为40G及以上
    需要先装一些常用的编译工具和开发包:
    

    切换阿里的源

    cd /etc/yum.repos.d/
    sudo mv CentOS-Base.repo CentOS-Base.repo.bak
    sudo wget -O CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-8.repo
    yum clean all
    yum makecache
    yum update -y
    

    安装 epel 源

    yum install -y  https://mirrors.aliyun.com/epel/epel-release-latest-8.noarch.rpm
    yum -y install make gcc gcc-c++ git automake libtool openssl openssl-devel expat-devel wget lrzsz libnghttp2
    

    下面下载的路劲统一放在 /usr/local/src

    1、httpd-2.4.46

    下载:wget https://mirror.bit.edu.cn/apache/httpd/httpd-2.4.46.tar.gz
    

    2、mysql-8.0.22

    下载:wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-8.0.22.tar.gz
    

    3、php-8.0.0

    下载:wget https://www.php.net/distributions/php-8.0.0.tar.gz
    

    4、apr-1.7.0(是 httpd 的依赖包)

    下载:wget https://mirror.bit.edu.cn/apache//apr/apr-1.7.0.tar.gz
    

    5、apr-util-1.6.1(是 httpd 的依赖包)

    下载:wget https://mirror.bit.edu.cn/apache//apr/apr-util-1.6.1.tar.gz
    

    6、pcre-8.44

    下载:wget https://ftp.pcre.org/pub/pcre/pcre-8.44.tar.gz
    

    7、boost-1_73_0(这是 mysql 5.7 版本以后必须的依赖包)

    下载:wget https://dl.bintray.com/boostorg/release/1.73.0/source/boost_1_73_0.tar.gz
    

    8、re2c

    下载:wget https://github.com/skvadrik/re2c/archive/2.0.3.tar.gz
      
    所有下载好的包都需要先解压
    tar zxf xxx.tar.gz
    

    (1)编译安装 apr

    cd /usr/local/src/apr-1.7.0/
    ./configure --prefix=/usr/local/apr // 指定程序存放路径,不存在时会自动创建
    make && make install
    echo $? // 如果返回0则正确安装
    注意:如果没有指定--prefix,那么可执行文件默认放在/usr /local/bin,库文件默认放在/usr/local/lib,配置文件默认放在/usr/local/etc,其它的资源文件放在/usr /local/share。
    

    (2)编译安装 apr-util

    cd /usr/local/src/apr-util-1.6.1
    ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr/bin/apr-1-config
    make && make install
    echo $?
    注意:apr-util需要指定apr中的一个配置文件bin/apr-1-config
    

    (3)编译安装 pcre

    cd /usr/local/src/pcre-8.44
    ./configure --prefix=/usr/local/pcre
    !make // 调用最近一次 make 开头的命令
    echo $?
    

    (4)编译安装 Apache

    4-1)初始化配置

    cd /usr/local/src/httpd-2.4.46/
    ./configure --prefix=/usr/local/apache --enable-so --enable-rewrite --enable-ssl --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util --with-pcre=/usr/local/pcre --enable-modules=most --enable-mpms-shared=all --with-mpm=event
    make && make install
    echo $?
    

    参数说明

    --prefix=/usr/local/apache 安装路径
    --enable-so 支持动态加载模块
    --enable-rewrite 支持网站地址重写
    --enable-ssl 支持 sll 加密
    --with-apr=/usr/local/apr 指定 apr 路径
    --with-apr-util=/usr/local/apr-util 指定 apr-util 路径
    --with-pcre=/usr/local/pcre 指定 pcre 路径
    --enable-modules=most 选择要编译的模块
    --enable-mpms-shared=all 支持当前平台上的动态加载的所有 MPM,并将它们构建为 DSO 模块
    --with-mpm=event 选择默认的 MPM
    注意:此时的配置文件是/usr/local/apache/conf/httpd.conf,默认网站根目录是/usr/local/apache/htdocs
    

    4-2)生成启动脚本

    如果此时重启服务器,那么可以使用 systemctl start|stop|restart|status apachectl 管理 Apache,但是没有办法 enable,因为这不是一个本地服务
    cp /usr/local/apache/bin/apachectl /etc/init.d/
    chmod +x /etc/init.d/apachectl
    

    4-3)写一个 systemctl 可以调用的 Apache 服务脚本,让它成为本地服务

    vim /usr/lib/systemd/system/apache.service
    [Unit]
    Description=apache
    After=network.target
    [Service]
    Type=forking
    ExecStart=/etc/init.d/apachectl start
    ExecReload=/etc/init.d/apachectl restart
    ExecStop=/etc/init.d/apachectl stop
    PrivateTmp=true
    [Install]
    WantedBy=multi-user.target
    设置完之后重启服务器 reboot
    systemctl start apachectl.service
    systemctl enable apache.service // 设置开机启动
    ps aux | grep apache
    不过可以看到 Apache 使用的是一个叫 daemon 的账户启动的,也可以创建一个专用的用户
    useradd -M -s /sbin/nologin apache // -M 不自动建立家目录,-s /sbin/nologin 不允许登录
    vim /usr/local/apache/conf/httpd.conf // 修改配置文件
    User apache // 167 行
    Group apache // 168 行
    chown -R apache.apache /usr/local/apache/ // 更改目录权限
    注意:如果防火墙没有关闭,请将端口号加到规则中
    firewall-cmd --permanent --zone=public --add-port=80/tcp
    firewall-cmd --reload
    firewall-cmd --permanent --zone=public --list-ports
    

    4-4)测试

    windows 上测试
    http://192.168.31.93/
    linux 上测试
    curl 192.168.31.93
    

    (5)编译安装 Mysql

    5-1)卸载系统自带 mysql 相关

    rpm -qa | grep mysql
    卸载系统自带的 mysql 和 mariadb,还有boost(这是 Mysql 5.7 以后必须的)
    yum -y remove mysql* mariadb* boost*
    

    5-2)安装依赖包

    yum install -y make cmake gcc gcc-c++ bison ncurses ncurses-devel libtirpc-devel libaio libaio-devel
    

    5-3)cmake 配置

    cd /usr/local/src/mysql-8.0.22/
    mkdir xiaochuan
    cd xiaochuan
    vim cmake.sh
    cmake .. -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DENABLED_LOCAL_INFILE=ON -DWITH_INNODB_MEMCACHED=ON -DWITH_SSL=system -        DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_FEDERATED_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 -DWITH_PERFSCHEMA_STORAGE_ENGINE=1 -DCOMPILATION_COMMENT="xiaochuan edition" -DDOWNLOAD_BOOST=1 -DCMAKE_CXX_COMPILER=/usr/bin/g++ -DWITH_BOOST=/tmp
    
    或者直接执行下面命令(一样)
    cmake .. -DCMAKE_INSTALL_PREFIX=/usr/local/mysql 
    -DDEFAULT_CHARSET=utf8 
    -DDEFAULT_COLLATION=utf8_general_ci 
    -DENABLED_LOCAL_INFILE=ON 
    -DWITH_INNODB_MEMCACHED=ON 
    -DWITH_SSL=system 
    -DWITH_INNOBASE_STORAGE_ENGINE=1 
    -DWITH_FEDERATED_STORAGE_ENGINE=1 
    -DWITH_BLACKHOLE_STORAGE_ENGINE=1 
    -DWITH_ARCHIVE_STORAGE_ENGINE=1 
    -DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 
    -DWITH_PERFSCHEMA_STORAGE_ENGINE=1 
    -DCOMPILATION_COMMENT="xiaochuan edition" 
    -DDOWNLOAD_BOOST=1 
    -DCMAKE_CXX_COMPILER=/usr/bin/g++ 
    -DWITH_BOOST=/tmp
    

    参数说明:

    DCMAKE_INSTALL_PREFIX:指定 Mysql 程序的安装目录,默认 /usr/local/mysql
    DMYSQL_DATADIR:指定 Mysql 程序的数据目录
    DSYSCONFDIR:初始化参数文件目录
    DWITH_MYISAM_STORAGE_ENGINE:安装 myisam 存储引擎
    DWITH_INNOBASE_STORAGE_ENGINE:安装 innodb 存储引擎
    DWITH_ARCHIVE_STORAGE_ENGINE:安装 archive 存储引擎
    DWITH_BLACKHOLE_STORAGE_ENGINE:安装 blackhole 存储引擎
    DWITH_FEDERATED_STORAGE_ENGINE:安装 federated 存储引擎
    DWITH_MEMORY_STORAGE_ENGINE:安装 memory 存储引擎
    DWITH_READLINE:使用 readline 功能
    DMYSQL_UNIX_ADDR:socket 文件路径,默认 /tmp/mysql.sock
    DMYSQL_TCP_PORT:服务端口号,默认 3306
    DENABLED_LOCAL_INFILE:指定是否允许本地执行 LOAD DATA INFILE,默认 OFF
    DEFAULT_CHARSET:指定服务器默认字符集,默认 latin1
    DEFAULT_COLLATION:指定服务器默认的校对规则,默认 latin1_general_ci
    DWITH_BOOST:指定 boost 的地址
    DWITHOUT_xxx_STORAGE_ENGINE:指定不编译的存储引擎
    DWITH_COMMENT:指定编译备注信息
    DFORCE_INSOURCE_BUILD:强制使用源码安装
    
    chmod +x cmake.sh
    ./cmake.sh
    
    // 如果报错,就执行下面两句
    make clean
    rm -rf CMakeCache.txt
    
    编译和安装最好不要一起执行,因为 mysql8 编译时间会比较久
    make // 编译
    make install // 安装
    

    编译过程中遇到的问题

    Q1、Could not find rpcgen

    wget https://github.com/thkukuk/rpcsvc-proto/releases/download/v1.4.2/rpcsvc-proto-1.4.2.tar.xz
    xz -d rpcsvc-proto-1.4.2.tar.xz
    tar -xvf rpcsvc-proto-1.4.2.tar
    cd rpcsvc-proto-1.4.2/
    ./configure && make && make install
    继续刚才那步操作
    

    5-4)创建数据库

    添加系统用户(Mysql 官网推荐写法,这是最严格的禁止登录。而 /sbin/nologin 只是不允许系统登录,但是可以使用 ftp 等其他服务登录。-r 创建的是系统用户)
    cat /etc/group | grep mysql
    cat /etc/passwd | grep mysql
    groupadd mysql
    useradd -M -s /bin/false -r -g mysql mysql
    
    // 创建相关目录
    mkdir -p /data/mysql/{3306,3307}/{data,log,tmp,innodb,innodb_log}
    cd /data/
    tree
    // 修改目录权限
    chown -R mysql:mysql /data/mysql
    chown -R mysql:mysql /usr/local/mysql/
    // 添加环境变量
    echo 'export PATH=$PATH:/usr/local/mysql/bin' >> /etc/profile
    source /etc/profile
    

    5-5)添加配置文件

    5-5-1)3306

    vim /data/mysql/3306/my3306.cnf
    [client]
    port=3306
    socket=/data/mysql/3306/mysql.sock
    [mysqld]
    port=3306
    user=mysql
    socket=/data/mysql/3306/mysql.sock
    pid-file=/data/mysql/3306/mysql.pid
    basedir=/usr/local/mysql
    datadir=/data/mysql/3306/data
    tmpdir=/data/mysql/3306/tmp
    open_files_limit=60000
    #explicit_defaults_for_timestamp
    server-id=3306
    lower_case_table_names=1
    character-set-server=utf8
    #federated
    #sql_mode=STRICT_TRANS_TABLES
    max_connections=1000
    max_connect_errors=100000
    interactive_timeout=86400
    wait_timeout=86400
    sync_binlog=0
    back_log=100
    default-storage-engine=InnoDB
    log_slave_updates=1
    #*********** Logs related settings ***********
    log-bin=/data/mysql/3306/log/mysql3306-bin
    binlog_format=mixed
    binlog_cache_size=32m
    max_binlog_cache_size=64m
    max_binlog_size=512m
    long_query_time=1
    log_output=FILE
    log-error=/data/mysql/3306/log/mysql-error.log
    slow_query_log=1
    slow_query_log_file=/data/mysql/3306/log/slow_statement.log
    #log_queries_not_using_indexes
    general_log=0
    general_log_file=/data/mysql/3306/log/general_statement.log
    #expire-logs-days = 14
    binlog_expire_logs_seconds=1728000
    relay-log=/data/mysql/3306/log/relay-bin
    relay-log-index=/data/mysql/3306/log/relay-bin.index
    #****** MySQL Replication New Feature*********
    master-info-repository=TABLE
    relay-log-info-repository=TABLE
    #relay-log-recovery
    #*********** INNODB Specific options ***********
    innodb_buffer_pool_size=2048M
    transaction-isolation=REPEATABLE-READ
    innodb_buffer_pool_instances=8
    innodb_file_per_table=1
    innodb_data_home_dir=/data/mysql/3306/innodb
    innodb_data_file_path=ibdata1:2048M:autoextend
    innodb_thread_concurrency=8
    innodb_log_buffer_size=16M
    innodb_log_file_size=128M
    innodb_log_files_in_group=3
    innodb_log_group_home_dir=/data/mysql/3306/innodb_log
    innodb_flush_log_at_trx_commit=2
    innodb_max_dirty_pages_pct=70
    innodb_flush_method=O_DIRECT
    [mysql]
    no-auto-rehash
    default-character-set=gbk
    prompt = (u@h) [d]>\_
    

    5-5-2)3307

    vim /data/mysql/3307/my3307.cnf
    [client]
    port=3307
    socket=/data/mysql/3307/mysql.sock
    [mysqld]
    port=3307
    user=mysql
    socket=/data/mysql/3307/mysql.sock
    pid-file=/data/mysql/3307/mysql.pid
    basedir=/usr/local/mysql
    datadir=/data/mysql/3307/data
    tmpdir=/data/mysql/3307/tmp
    open_files_limit=60000
    #explicit_defaults_for_timestamp
    server-id=3307
    lower_case_table_names=1
    character-set-server=utf8
    #federated
    #sql_mode=STRICT_TRANS_TABLES
    max_connections=1000
    max_connect_errors=100000
    interactive_timeout=86400
    wait_timeout=86400
    sync_binlog=0
    back_log=100
    default-storage-engine=InnoDB
    log_slave_updates=1
    #*********** Logs related settings ***********
    log-bin=/data/mysql/3307/log/mysql3306-bin
    binlog_format=mixed
    binlog_cache_size=32m
    max_binlog_cache_size=64m
    max_binlog_size=512m
    long_query_time=1
    log_output=FILE
    log-error=/data/mysql/3307/log/mysql-error.log
    slow_query_log=1
    slow_query_log_file=/data/mysql/3307/log/slow_statement.log
    #log_queries_not_using_indexes
    general_log=0
    general_log_file=/data/mysql/3307/log/general_statement.log
    #expire-logs-days = 14
    binlog_expire_logs_seconds=1728000
    relay-log=/data/mysql/3307/log/relay-bin
    relay-log-index=/data/mysql/3307/log/relay-bin.index
    #****** MySQL Replication New Feature*********
    master-info-repository=TABLE
    relay-log-info-repository=TABLE
    #relay-log-recovery
    #*********** INNODB Specific options ***********
    innodb_buffer_pool_size=2048M
    transaction-isolation=REPEATABLE-READ
    innodb_buffer_pool_instances=8
    innodb_file_per_table=1
    innodb_data_home_dir=/data/mysql/3307/innodb
    innodb_data_file_path=ibdata1:2048M:autoextend
    innodb_thread_concurrency=8
    innodb_log_buffer_size=16M
    innodb_log_file_size=128M
    innodb_log_files_in_group=3
    innodb_log_group_home_dir=/data/mysql/3307/innodb_log
    innodb_flush_log_at_trx_commit=2
    innodb_max_dirty_pages_pct=70
    innodb_flush_method=O_DIRECT
    [mysql]
    no-auto-rehash
    default-character-set=gbk
    prompt = (u@h) [d]>\_
    

    5-5-3)3306默认

    vim /data/mysql/my.cnf
    [client]
    port=3306
    socket=/data/mysql/mysql.sock
    [mysqld]
    port=3306
    user=mysql
    socket=/data/mysql/mysql.sock
    pid-file=/data/mysql/mysql.pid
    basedir=/usr/local/mysql
    datadir=/data/mysql/data
    tmpdir=/data/mysql/tmp
    open_files_limit=60000
    #explicit_defaults_for_timestamp
    server-id=3306
    lower_case_table_names=1
    character-set-server=utf8
    #federated
    #sql_mode=STRICT_TRANS_TABLES
    max_connections=1000
    max_connect_errors=100000
    interactive_timeout=86400
    wait_timeout=86400
    sync_binlog=0
    back_log=100
    default-storage-engine=InnoDB
    log_slave_updates=1
    #*********** Logs related settings ***********
    log-bin=/data/mysql/log/mysql3306-bin
    binlog_format=mixed
    binlog_cache_size=32m
    max_binlog_cache_size=64m
    max_binlog_size=512m
    long_query_time=1
    log_output=FILE
    log-error=/data/mysql/log/mysql-error.log
    slow_query_log=1
    slow_query_log_file=/data/mysql/log/slow_statement.log
    #log_queries_not_using_indexes
    general_log=0
    general_log_file=/data/mysql/log/general_statement.log
    #expire-logs-days = 14
    binlog_expire_logs_seconds=1728000
    relay-log=/data/mysql/log/relay-bin
    relay-log-index=/data/mysql/log/relay-bin.index
    #****** MySQL Replication New Feature*********
    master-info-repository=TABLE
    relay-log-info-repository=TABLE
    #relay-log-recovery
    #*********** INNODB Specific options ***********
    innodb_buffer_pool_size=2048M
    transaction-isolation=REPEATABLE-READ
    innodb_buffer_pool_instances=8
    innodb_file_per_table=1
    innodb_data_home_dir=/data/mysql/innodb
    innodb_data_file_path=ibdata1:2048M:autoextend
    innodb_thread_concurrency=8
    innodb_log_buffer_size=16M
    innodb_log_file_size=128M
    innodb_log_files_in_group=3
    innodb_log_group_home_dir=/data/mysql/innodb_log
    innodb_flush_log_at_trx_commit=2
    innodb_max_dirty_pages_pct=70
    innodb_flush_method=O_DIRECT
    [mysql]
    no-auto-rehash
    default-character-set=gbk
    prompt = (u@h) [d]>\_
    

    5-6)初始化数据库

    // 3306
    mysqld --defaults-file=/data/mysql/3306/my3306.cnf --initialize --user=mysql
    // 3307
    mysqld --defaults-file=/data/mysql/3307/my3307.cnf --initialize --user=mysql
    

    5-7)启动服务

    // 3306
    mysqld_safe --defaults-file=/data/mysql/3306/my3306.cnf --user=mysql &
    // 3307
    mysqld_safe --defaults-file=/data/mysql/3307/my3307.cnf --user=mysql &
    

    5-8)登录数据库

    这里以 3306 实例为例,3307 步骤相同,只需要注意端口号即可,即大写的 -P
    // 查看当前错误日志,有一个 root@localhost:xxxxxx,这个就是密码
    more /data/mysql/3306/log/mysql-error.log
    mysql -uroot -p'xxxxxx' -P3306 -S /data/mysql/3306/mysql.sock // 登录
    alter user 'root'@'localhost' identified with sha256_password by 'new_password' password expire interval 360 day; // 修改密码
    

    (6)编译安装 php

    安装 epel 存储库
    sudo dnf install https://dl.Fedoraproject.org/pub/epel/epel-release-latest-8.noarch.rpm
    
    yum install -y libmcrypt libmcrypt-devel autoconf freetype gd libmcrypt libpng libpng-devel libjpeg libxml2 libxml2-devel zlib curl curl-devel re2c php-mcrypt php-pear python36-devel libxml2-devel.x86_64 sqlite-devel.x86_64 libmcrypt-devel.x86_64 oniguruma.x86_64
     
    cd /usr/local/src/php-8.0.0/
    
    ./configure --prefix=/usr/local/php80 --with-config-file-path=/usr/local/php80/etc --enable-mbstring --enable-ftp --enable-gd --enable-gd-jis-conv --enable-mysqlnd --enable-pdo --enable-sockets --enable-fpm --enable-xml --enable-soap --enable-pcntl --enable-cli --with-openssl --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd --with-pear --with-zlib --with-iconv --with-curl --with-config-file-scan-dir=/usr/local/php80/etc/php.d
    

    参数说明

    --with-config-file-path=/usr/local/php/etc/ 指定配置文件目录
    --with-apxs2=/usr/local/apache2/bin/apxs 指定apache动态模块位置
    --with-mysql=/usr/local/mysql/     指定mysql位置
    --with-libxml-dir=/usr/local/libxml2/ 指定libxml位置
    --with-jpeg-dir=/usr/local/jpeg6/ 指定jpeg位置
    --with-png-dir=/usr/local/libpng/ 指定libpng位置
    --with-freetype-dir=/usr/local/freetype/ 指定freetype位置
    --with-mcrypt=/usr/local/libmcrypt/     指定libmcrypt位置
    --with-mysqli=/usr/local/mysql/bin/mysql_config 指定mysqli位置
    --with-gd 启用gd库
    --enable-soap 支持soap服务
    --enable-mbstring=all 支持多字节,字符串
    --enable-sockets 支持套接字
    --with-pdo-mysql=/usr/local/mysql 启用mysql的pdo模块支持
    --without-pear 不安装pear(安装pear需要连接互联网。 PEAR是PHP扩展与应用库)
    

    丰富的配置参数说明

    https://www.php.net/manual/en/configure.about.php

    安装过程中,会出现的错误

    Error 1、'libxml-2.0 not found'

    解决办法:
    yum install -y libxml2-devel.x86_64
    

    Error2、'sqlite3' not found

    解决办法:
    yum install -y sqlite-devel.x86_64
    

    Error3、'libcurl' not found

    解决办法:
    wget https://curl.haxx.se/download/curl-7.74.0.tar.gz
    tar zxvf curl-7.74.0.tar.gz
    cd curl-7.74.0/
    sudo ./configure
    sudo make
    sudo make install
    

    Error4、make: *** [sapi/cli/php] Error 1

    vim Makefile
    查找 'EXTRA_LIBS = ...' 在结尾加上 -lcrypt -liconv
    

    Error5、configure: error: DBA: Could not find necessary header file(s).

    yum install -y gdbm-devel
    

    Error6、configure: error: Package requirements (libpng) were not met:

    yum search libpng
    sudo yum install -y libpng-devel.x86_64
    

    Error7、Package 'oniguruma', required by

    wget https://github.com/kkos/oniguruma/archive/v6.9.6.tar.gz -O /usr/local/src/oniguruma-6.9.6.tar.gz
    cd /usr/local/src/
    tar zxvf oniguruma-6.9.6.tar.gz
    cd oniguruma-6.9.6
    ./autogen.sh && ./configure && make && sudo make install
    

    6-1)编译&安装

    make
    // 由于是尝鲜版会提示 Build complete. Don't forget to run 'make test'. make test这一步就先省略了
    make install
    
    // make install 之后提示下面语句,是正常的
    // Installing PDO headers: /usr/local/php80/include/php/ext/pdo/
    

    6-2)验证PHP

    /usr/local/php80/bin/php -v
    

    6-3)环境配置

    cd /usr/local/src/php-8.0.0/
    ln -s /usr/local/php80/bin/php /usr/bin/php80
    cp php.ini-development /usr/local/php80/etc/php.ini
    cp /usr/local/php80/etc/php-fpm.conf.default /usr/local/php80/etc/php-fpm.conf
    cp /usr/local/php80/etc/php-fpm.d/www.conf.default /usr/local/php80/etc/php-fpm.d/www.conf
    cp sapi/fpm/init.d.php-fpm /etc/init.d/php80-fpm
    chmod +x /etc/init.d/php80-fpm
    

    6-4)验证配置路径

    [root@MiWiFi-R3600-srv php-8.0.0]# php80 --ini
    Configuration File (php.ini) Path: /usr/local/php80/etc/
    Loaded Configuration File: /usr/local/php80/etc/php.ini
    Scan for additional .ini files in: /usr/local/php80/etc/php.d
    Additional .ini files parsed: (none)
    

    6-5)启动 fpm

    /etc/init.d/php80-fpm status
    /etc/init.d/php80-fpm start
    /etc/init.d/php80-fpm stop
    /etc/init.d/php80-fpm restart
    // 如果要开启多个版本的 php-fpm 需要修改配置
    vim /usr/local/php80/etc/php-fpm.d/www.conf
    listen = 127.0.0.1:9001 // 36 行
    // 保存,退出,可以启动了
    

    6-6)验证 fpm

    ps aux | grep php-fpm
    

    6-7)浏览器访问

    http://192.168.31.111/index.php
    如果显示源代码或者提示下载文件,就做以下操作
    vim /usr/local/apache/conf/httpd.conf
    # 在 394 行后面添加支持 php
    AddType application/x-httpd-php .php .phtml
    AddType application/x-httpd-php-source .phps
    # 找到 LoadModule 在后面追加
    # php7
    LoadModule php7_module modules/libphp7.so
    # php8
    LoadModule php_module modules/libphp.so
    # 保存,退出
    :wq
    // 重启 apache
    systemctl restart apache
    

    alt img

  • 相关阅读:
    git使用
    Git常用命令梳理
    git fetch 更新远程代码到本地仓库
    理解RESTful架构
    漫谈五种IO模型(主讲IO多路复用)
    python 单下划线/双下划线使用总结
    闰秒导致MySQL服务器的CPU sys过高
    闰秒问题
    Java线上应用故障排查之一:高CPU占用
    ZooKeeper安装与配置
  • 原文地址:https://www.cnblogs.com/xiao-chuan-/p/14124370.html
Copyright © 2011-2022 走看看