我的编程空间,编程开发者的网络收藏夹
学习永远不晚

ubuntu20+PHP项目运行环境搭建

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

ubuntu20+PHP项目运行环境搭建

ubuntu20(root)+PHP+nginx+mysql

nginx【较新版】

wget http://nginx.org/keys/nginx_signing.keyapt-key add nginx_signing.keylsb_release -avi /etc/apt/sources.list# lsb_release -a 返回的Ubuntu系统版本编码(英文) 添加到sources.list中。【focal为Ubuntu20.04对应版本编码】deb http://nginx.org/packages/ubuntu/ focal nginxdeb-class="lazy" data-src http://nginx.org/packages/ubuntu/ focal nginx# 保存sources.list退出:wq# 安装nginxapt updateapt -y install nginxsystemctl enable/disable/status/start/stop/restart nginx# 查看Nginx版本nginx -v1.22.0

PHP7.4【修改数字即可安装不同版本】

# 彻底卸载apt安装的PHPaptitude purge `dpkg -l | grep php| awk '{print $2}' |tr "\n" " "`            apt -y install software-properties-commonadd-apt-repository ppa:ondrej/phpapt updateapt -y install php7.4 php7.4-fpm# 安装PHP扩展,php7.4-dev用于后面pecl安装扩展时自动编译(支持命令:phpize)apt -y install php7.4-mcrypt php7.4-mbstring php7.4-curl php7.4-cli php7.4-mysql php7.4-gd php7.4-intl php7.4-xsl php7.4-zip php7.4-dev php7.4-xml php7.4-soapsystemctl enable/disable/status/start/stop/restart php7.4-fpm# 查询PHP版本php -v7.4.22

mysql8

apt install -y mysql-server

mysql8设置root密码

第一步:mysql8默认安装完成后,root账户没有密码,直接执行命令“mysql”即可登录。

第二步:还原密码设置。

update mysql.user set authentication_string='' where user='root';update mysql.user set plugin='mysql_native_password' where user='root';FLUSH PRIVILEGES;

第三步:通过mysql提供的脚本来设置密码。
MySQL安装随附一个名为的脚本mysql_secure_installation。可以借助它设置我们MYSQL服务器的安全性!

mysql_secure_installation

按提示执行即可。最后出现“All done!”说明脚本执行完成。直接使用新设置密码登录即可。


整合PHP+nginx

find / -name www.confvi /etc/php/7.4/fpm/pool.d/www.conf# 设置php-fpm通过监听端口方式工作;listen = /run/php/php7.4-fpm.socklisten = 127.0.0.1:9000

nginx配置文件路径

ps -ef|grep nginx# nginx配置文件地址root      498847       1  0 00:42 ?        00:00:00 nginx: master process /usr/sbin/nginx -c /etc/nginx/nginx.confvi /etc/nginx/nginx.conf# 自定义配置文件位置include /etc/nginx/conf.dclass Test {    protected $DB_SQLSERVER = array(        'db_type'  => 'sqlsrv',        'db_user'  => 'user',        'db_pwd'   => "password",        'db_host'  => '127.0.0.1',        'db_port'  => '1433',        'db_name'  => 'dbname',        'db_charset' => 'UTF8',    );   public function test(){       $sql='select * from table_name where id =1';   dump($this->querySql($sql));   }    protected $sqlsrvConn = null;    protected function sqlsrvConn(){        $dbServerName = $this->DB_SQLSERVER['db_host'] . "," . $this->DB_SQLSERVER['db_port'];        $connInfo = array();        $connInfo['UID'] = $this->DB_SQLSERVER['db_user'];        $connInfo['PWD'] = $this->DB_SQLSERVER['db_pwd'];        $connInfo['Database'] = $this->DB_SQLSERVER['db_name'];        $connInfo['Encrypt'] = 'no'; // 不使用SSL加密        $this->sqlsrvConn = sqlsrv_connect($dbServerName,$connInfo);        if($this->sqlsrvConn === false){            $this->ajaxReturn(genInfoTip(CODE_FAIL, "sqlserver数据库连接失败:".sqlsrv_errors()));        }    }    public function querySql($sql){        if(empty($sql)){            return genInfoTip(CODE_FAIL, "sql不能为空");        }        $this->sqlsrvConn();        $queryRet = sqlsrv_query($this->sqlsrvConn, $sql);        if($queryRet === false){            $this->ajaxReturn(genInfoTip(CODE_FAIL, "sqlserver数据库查询异常:".sqlsrv_errors()));        }        $result = array();        while(($row = sqlsrv_fetch_array($queryRet))){            $result[] = $row;        }        return $result;    }    public function execSql($sql){        if(empty($sql)){            return genInfoTip(CODE_FAIL, "sql不能为空");        }        $this->sqlsrvConn();        $exec = sqlsrv_query($this->sqlsrvConn, $sql);        if($exec === false){            $this->ajaxReturn(genInfoTip(CODE_FAIL, "sqlserver数据库sql操作异常:".sqlsrv_errors()));        }        $num=sqlsrv_rows_affected($exec);//返回修改的行数        return $num;    }

问题

报错:SQLSTATE[08001]: [Microsoft][ODBC Driver 18 for SQL Server]SSL Provider: [error:0A000086:SSL routines::certificate verify failed:self-signed certificate]


看到报错SSL,又是verify failed。怀疑是http传输加密,导致验证失败。

考虑是否可以取消SSL加密。

查询官网(使用连接字符串关键字 - SQL Server Native Client | Microsoft Learn

发现有个字段和加密相关:Encrypt

然后直接sqlcmd测试(sqlcmd使用方式参考:使用 sqlcmd 进行连接 - ODBC Driver for SQL Server | Microsoft Learn):

 测试 -N 参数:

最后,发现ThinkPHP3.2中并不支持此参数。故上文Test.class.php中采用直连方式 配置此参数,最终连接成功!

来源地址:https://blog.csdn.net/pjz161026/article/details/127399345

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

ubuntu20+PHP项目运行环境搭建

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

php如何搭建运行环境

本篇内容介绍了“php如何搭建运行环境”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、选择操作系统首先,你需要选择一个适合你的操作系统进行
2023-07-05

linux如何搭建php运行环境

要在Linux上搭建PHP运行环境,可以按照以下步骤进行操作:1. 安装Apache HTTP服务器:在终端中运行以下命令来安装Apache服务器:```sudo apt-get updatesudo apt-get install apa
2023-08-29

Linux 环境搭建推荐教程(php运行环境)

一、系统约定 软件源代码包存放位置:/usr/local/src 源码包编译安装位置(prefix):/usr/local/software_name 脚本以及维护程序存放位置:/usr/local/sbin mysql 数据库位置:/va
2022-06-12

win7下PHP运行环境搭建(apache2+mysql+php)

php版本:php-5.3.2-Win32-VC6-x86,VC9是专门为IIS定制的,VC6 是为了其他WEB服务软件提供的,如 Apache。我下载的是ZIP包 下载地址 mysql版本:Windows (x86, 32-bit), M
2023-05-25

centos7上如何搭建php运行环境

这篇文章主要讲解了“centos7上如何搭建php运行环境”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“centos7上如何搭建php运行环境”吧!安装Apache首先,我们需要在CentO
2023-07-05

如何搭建php服务器运行环境

要搭建PHP服务器运行环境,需要进行以下步骤:1、安装Web服务器Web服务器是用于运行PHP脚本的基础,常见的Web服务器有Apache、Nginx等。可以到官网下载安装包,或者使用系统自带的包管理工具进行安装。2、安装PHPPHP是用于
2023-03-15

hadoop运行环境怎么搭建

搭建Hadoop运行环境需要以下步骤:下载Hadoop安装包:首先需要到官方网站下载Hadoop的安装包,选择适合的版本和操作系统。配置环境变量:设置Hadoop的环境变量,包括JAVA_HOME、HADOOP_HOME等。可以将这些变量添
hadoop运行环境怎么搭建
2024-03-14

vue项目环境如何搭建

这篇文章主要介绍了vue项目环境如何搭建的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue项目环境如何搭建文章都会有所收获,下面我们一起来看看吧。一、node.js下载和安装官网下载安装nodejs,会自动捆
2023-06-30

如何搭建hadoop运行环境

这篇文章主要介绍如何搭建hadoop运行环境,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! Hadoop作为搭建大数据处理平台的重要“基石”,关于它的分析和讲解的文章已经有很多了。Hadoop本身是一分布式的系统,因
2023-06-02

云服务器php运行环境怎么搭建

要搭建云服务器上的PHP运行环境,可以按照以下步骤进行操作:1. 选择云服务器:根据自己的需求选择一个云服务器。2. 安装操作系统:在云服务器上安装一个适合的操作系统,常用的有Ubuntu、CentOS等。3. 安装Web服务器:常用的We
2023-08-19

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录