私は docker を使用してサーバーの動作環境を構築していました。最近、友人がサーバー上に PHP 環境を手動で構築するように依頼しました。非常に時間がかかり、実行できませんでした。もう遊んでください。
最近、友人から PHP 環境のセットアップを手伝ってほしいと頼まれましたが、当初は docker を直接使用してほしかったのです。しかし、購入したサーバーはジュシタ製で、データベースには外部ネットワークがなく、内部ネットワーク経由でしかアクセスできませんでした。 dockerを使ってホストのネットワークにアクセスすると、時々アドレスが見つからず常にサービス全体が中断されてしまうため、仕方なく引っ越しをして一つ一つ環境をインストール、再構築していきます。私も初心者で、長い間悩んだ末にやっと分かりました。
サーバーにインストールされている centos7 システムで、まず Alibaba ソースを置き換えます。
$ cd /etc/yum.repos.d/$ cp CentOS-Base.repo CentOS-Base.repo.bak $ wget -O CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo $ yum clean all $ yum update $ yum makecache # 查看已安装的PHP,有的话rpm -e卸载 $ yum list installed | grep php
EPEL (Extra Packages for Enterprise Linux) は、RHEL および CentOS などの派生ディストリビューションに高品質のソフトウェア パッケージを提供するために、Fedora コミュニティによって作成されました。 。 プロジェクト。高品質の無料売春ソフトウェア ソースです。
インストール後、yum install packageName
を使用して、以前はコンパイルしてインストールする必要があった多くのソフトウェア、一般的に使用されるソフトウェア、または Nginx などのより一般的なソフトウェアをインストールできます。
$ yum install epel-release
EPEL ソースに加えて、CentOS には REMI ソースもあります。REMI ソースはソフトウェアの最新バージョンを保証しますが、最新バージョンであることを保証するものではありません。ソフトウェアは安定しています。バージョン。主に最新バージョンの PHP をインストールするために使用されます。
$ rpm -ivh https://mirrors.tuna.tsinghua.edu.cn/remi/enterprise/remi-release-7.rpm
まずはインストール可能なPHPバージョンを確認してください
$ yum repolist all | grep php * remi-php72: mirrors.tuna.tsinghua.edu.cn remi-php70 Remi's PHP 7.0 RPM repositor disabled remi-php70-debuginfo/x86_64 Remi's PHP 7.0 RPM repositor disabled remi-php70-test Remi's PHP 7.0 test RPM repo disabled remi-php70-test-debuginfo/x86_64 Remi's PHP 7.0 test RPM repo disabled remi-php71 Remi's PHP 7.1 RPM repositor disabled remi-php71-debuginfo/x86_64 Remi's PHP 7.1 RPM repositor disabled remi-php71-test Remi's PHP 7.1 test RPM repo disabled remi-php71-test-debuginfo/x86_64 Remi's PHP 7.1 test RPM repo disabled!remi-php72 Remi's PHP 7.2 RPM repositor enabled: 412remi-php72-debuginfo/x86_64 Remi's PHP 7.2 RPM repositor disabled remi-php72-test Remi's PHP 7.2 test RPM repo disabled remi-php72-test-debuginfo/x86_64 Remi's PHP 7.2 test RPM repo disabled remi-php73 Remi's PHP 7.3 RPM repositor disabled remi-php73-debuginfo/x86_64 Remi's PHP 7.3 RPM repositor disabled remi-php73-test Remi's PHP 7.3 test RPM repo disabled remi-php73-test-debuginfo/x86_64 Remi's PHP 7.3 test RPM repo disabled remi-php74 Remi's PHP 7.4 RPM repositor disabled remi-php74-debuginfo/x86_64 Remi's PHP 7.4 RPM repositor disabled remi-php74-test Remi's PHP 7.4 test RPM repo disabled remi-php74-test-debuginfo/x86_64 Remi's PHP 7.4 test RPM repo disabled remi-php80 Remi's PHP 8.0 RPM repositor disabled remi-php80-debuginfo/x86_64 Remi's PHP 8.0 RPM repositor disabled remi-php80-test Remi's PHP 8.0 test RPM repo disabled remi-php80-test-debuginfo/x86_64 Remi's PHP 8.0 test RPM repo disabled
デフォルトのインストールバージョンを設定します。ここではphp7.2
$ yum-config-manager --enable remi-php72 # 注意 如果提示 yum-config-manager 找不到的话需要先安装下 yum-utils,在来执行上面的配置 $ yum -y install yum-utils # 最后选择自己想安装的PHP版本即可 $ yum -y install php $ php -v $ php -m
# 查找php对应版本的扩展,我这里是7.2就写的php72-php $ yum search php72-php * base: mirrors.cloud.aliyuncs.com * extras: mirrors.cloud.aliyuncs.com * remi-php72: mirror.innosol.asia * remi-safe: mirror.innosol.asia * updates: mirrors.cloud.aliyuncs.com============================================================================================================= N/S matched: php72-php ==============================================================================================================php72-php-pecl-handlebars-devel.x86_64 : php72-php-pecl-handlebars developer files (header)php72-php-pecl-http-message-devel.x86_64 : php72-php-pecl-http-message developer files (headers)php72-php-pecl-propro-devel.x86_64 : php72-php-pecl-propro developer files (header)php72-php-pecl-psr-devel.x86_64 : php72-php-pecl-psr developer files (header)php72-php-pecl-raphf-devel.x86_64 : php72-php-pecl-raphf developer files (header)php72-php-pecl-swoole-devel.x86_64 : php72-php-pecl-swoole developer files (header)...# 安装扩展,注意扩展名不需要带上PHP的版本号,下面是我在Laravel里需要的一些扩展 $ yum -y install php-fpm php-bcmath php-mbstring php-mysqli php-mysqlnd php-pdo php-pdo_mysql php-posix php-shmop php-simplexml php-sodium php-xml php-xmlreader php-xmlwriter php-xsl php-zip php-opcache # 然后查看扩展是否安装成功 $ php -m
# 启动 $ systemctl start php-fpm # 停止or重启 $ systemctl stop php-fpm $ systemctl restart php-fpm # 重载 $ systemctl reload php-fpm # 设置开机启动 $ systemctl enable php-fpm # 禁止开机启动 $ systemctl disable php-pfm
最後に PHP-FPM のプロセスを確認します
$ ps aux | grep php root 1728 0.0 0.1 455280 12780 ? Ss Sep07 0:01 php-fpm: master process (/etc/php-fpm.conf)apache 1998 0.0 0.6 558512 48084 ? S Sep07 0:15 php-fpm: pool www apache 2873 0.0 0.4 542200 36012 ? S Sep07 0:19 php-fpm: pool www apache 2874 0.0 0.3 536164 29212 ? S Sep07 0:19 php-fpm: pool www apache 2875 0.0 0.4 542200 34832 ? S Sep07 0:21 php-fpm: pool www
service php-fpm status
php-fpm.conf
ファイルのデフォルトは /etc/php-fpm.conf
php.ini
file デフォルトでは、/etc/php.ini
php.ini
ファイルには変更が必要なパラメータがいくつかあります。編集して検索を入力してください。このキーを使用した max
説明を読んで、キャラクターの設定の一部 (メモリ、ファイル サイズ、実行時間などの制限) を自分で変更してください。
修正後 systemctl reload php-fpm
実行するだけです。
# 安装Nginx最新源 $ yum localinstall http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm $ yum repolist enabled | grep "nginx*"# 安装nginx $ yum -y install nginx # 启动nginx $ service nginx start # 测试nginx配置文件是否正常 $ nginx -t # 平滑加载 $ nginx -s reload # 设置nginx服务器开机自启动 $ systemctl enable nginx.service # 检查开机自动是否设置成功 $ systemctl list-dependencies | grep nginx
nginx の再起動や、PID が空であるか見つからないという他のプロンプトが表示された場合は、残留物があるかどうかを確認できます。それらを強制終了してから、 nginx -c /etc/nginx/nginx.conf
設定ファイルを指定します。
service nginx status を通じて nginx のステータスを確認できます。
/etc/nginx/ にあり、デフォルトのエラー ログは
/var/log/nginx/error.log にあります。メインサーバー設定 ファイルは
/etc/nginx/conf.d/*.conf
server { # 这里做了Https的相关配置 listen 443 ssl http2; server_name your_server_name; # 项目访问根目录 root /xxx/www/public; # ssl证书相关 ssl_certificate /xxx/certs/xxx.pem; ssl_certificate_key /xxx/certs/xxx.key; ssl_session_timeout 5m; ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4; ssl_protocols TLSv1 TLSv1.1 TLSv1.2; ssl_prefer_server_ciphers on; # 添加几条有关安全的响应头;与 Google+ 的配置类似,详情参见文末。 add_header X-Frame-Options "SAMEORIGIN"; add_header X-XSS-Protection "1; mode=block"; add_header X-Content-Type-Options "nosniff"; # 站点默认页面;可指定多个,将顺序查找。 # 例如,访问 http://example.com/ Nginx 将首先尝试「站点根目录/index.html」是否存在,不存在则继续尝试「站点根目录/index.htm」,以此类推... index index.html index.htm index.php; # 指定字符集为 UTF-8 charset utf-8; # Laravel 默认重写规则;删除将导致 Laravel 路由失效且 Nginx 响应 404。 location / { try_files $uri $uri/ /index.php?$query_string; } # 关闭 [/favicon.ico] 和 [/robots.txt] 的访问日志。 # 并且即使它们不存在,也不写入错误日志。 location = /favicon.ico { access_log off; log_not_found off; } location = /robots.txt { access_log off; log_not_found off; } # 将 [404] 错误交给 [/index.php] 处理,表示由 Laravel 渲染美观的错误页面。 error_page 404 /index.php; # URI 符合正则表达式 [\.php$] 的请求将进入此段配置 location ~ \.php$ { # 配置 FastCGI 服务地址,可以为 IP:端口,也可以为 Unix socket。 fastcgi_pass 127.0.0.1:9000; # 配置 FastCGI 的主页为 index.php。 fastcgi_index index.php; # 配置 FastCGI 参数 SCRIPT_FILENAME 为 $realpath_root$fastcgi_script_name。 fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name; # 引用更多默认的 FastCGI 参数。 include fastcgi_params; } # 通俗地说,以上配置将所有 URI 以 .php 结尾的请求,全部交给 PHP-FPM 处理。 # 除符合正则表达式 [/\.(?!well-known).*] 之外的 URI,全部拒绝访问 # 也就是说,拒绝公开以 [.] 开头的目录,[.well-known] 除外 location ~ /\.(?!well-known).* { deny all; }}server { listen 80; server_name your_server_name; return 301 https://your_server_name$request_uri;}
nginx -s reload.何か問題がある場合は、nginx エラー ログ ファイルを忘れずに確認してください。これは非常に便利です。基本的な落とし穴
/var/log/nginx/error.log に記録されます。
# 安装mysql源 $ yum -y localinstall http://dev.mysql.com/get/mysql57-community-release-el7-7.noarch.rpm $ yum repolist enabled | grep "mysql.*-community.*"# 安装Mysql $ yum -y install mysql-community-server install mysql-community-devel # 启动mysql $ service mysqld start # 检查mysql启动是否正常 $ service mysqld status 或者 ps -ef | grep mysql # 设置mysqld服务开机自启动 $ systemctl enable mysqld.service # 使用yum安装Mysql,启动会系统会自动生成一个随机的数据库密码,需要修改下 # 查看mysql的随机密码 $ grep 'temporary password' /var/log/mysqld.log # 终端登录Mysql $ mysql -hlocalhost -u root -p xxx # 修改密码 $ ALTER USER 'root'@'localhost' IDENTIFIED BY 'Yourpassword';
storage ディレクトリと
bootstrap/cache このディレクトリは Web サーバーから書き込み可能である必要があります。
$ ps aux | grep php-fpm root 1728 0.0 0.1 455280 12780 ? Ss Sep07 0:01 php-fpm: master process (/etc/php-fpm.conf)apache 1998 0.0 0.4 542128 31616 ? S Sep07 0:17 php-fpm: pool www apache 2873 0.0 0.5 552440 46508 ? S Sep07 0:22 php-fpm: pool www apache 2874 0.0 0.6 560740 52748 ? S Sep07 0:22 php-fpm: pool www...
apache ユーザーによって実行されていることがわかります。そのため、上記の 2 つのディレクトリを
apache に変更する必要があります (変更はしません)このゴーストはユーザーによって作成されたものであるか、おそらく php-fpm がデフォルトでインストールされたときに作成されたものであることを知っています...)。
# 暴力一些 $ chown -R apache:apache /xxx/storage/$ chown -R apache:apache /xxx/bootstrap/cache/# 在给个755权限 $ chmod -R 755 /xxx/storage/$ chmod -R 755 /xxx/bootstrap/cache/
相关推荐:最新的五个Laravel视频教程
以上がCentos7でLaravel環境を構築する方法(非Docker)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。