ThinkPHP5连接远程Mysql数据库SSL的配置

案例场景:

        在工厂做ERP数据维护期间,想从第三方供应商数据库获取数据自己做ERP数据查询,我觉得这样做既方便了自己做数据查询和维护,而且又不用工厂花钱,有时候用户使用一些ERP报表查数据超慢,而且很多数据格式又看不懂或者不是他们想要,所以我觉得有必要将自己或用户常查询的数据页面化。

问题描述:

问题描述:tp连接远程MySQL数据库是需要ssl相关配置,如果没有配置就会报错,提示必须配置ssl文件,而连不上数据库,当时百度了许久,终于找到了该配置的方法,必须记录下来。


解决方案:

  1. 前提是需要获得证书文件 # MyServerCACert.pem
  2. tp5数据库文件database.php连接配置(关键点)
return [
   // 数据库类型
    'type'            => 'mysql',
    // 远程MySQL服务器地址
    'hostname'        => '**********.mysql.databasee.com',
    // 远程连接的数据库名
    'database'        => '****',
    // 登录MySQL的远程登录用户名
    'username'        => '********',
    // MySQL远程登录密码
    'password'        => '****',
    // 端口
    'hostport'        => '3306',
    // 连接dsn
    'dsn'             => '',
    // 数据库连接参数 (**关键配置参数,指定你的pem文件路径**)
    'params'          => [
        PDO::MYSQL_ATTR_SSL_CA=>'/MyServerCACert.pem'
    ],
    // 数据库编码默认采用utf8
    'charset'         => 'utf8',
    // 数据库表前缀
    'prefix'          => '',
    // 数据库调试模式
    'debug'           => true,
    // 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
    'deploy'          => 0,
    // 数据库读写是否分离 主从式有效
    'rw_separate'     => false,
    // 读写分离后 主服务器数量
    'master_num'      => 1,
    // 指定从服务器序号
    'slave_no'        => '',
    // 自动读取主库数据
    'read_master'     => false,
    // 是否严格检查字段是否存在
    'fields_strict'   => true,
    // 数据集返回类型
    'resultset_type'  => 'array',
    // 自动写入时间戳字段
    'auto_timestamp'  => false,
    // 时间字段取出后的默认时间格式
    'datetime_format' => 'Y-m-d H:i:s',
    // 是否需要进行SQL性能分析
    'sql_explain'     => false,
    // 开启断线重连
    'break_reconnect' => true,
    // 断线标识字符串
    'break_match_str' => [
        '数据库断开链接,正在重连。。。',
    ],
];

如果其他配置没问题的话,基本上成功连接远程的MySQL数据库进行操作了。
END!!!

注:如有缺陷或不足请反馈,我及时纠正,谢谢!!

笔记 2020-09-08


版权声明:本文为Program_ERP原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。