【phabricator】代码审查工具issue

2024-03-10 11:32

本文主要是介绍【phabricator】代码审查工具issue,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在首次登录后,不要关闭账号密码登录方式,否则admin用户下次无法登录。

如果登录不进去了,官网给了解决办法

https://secure.phabricator.com/book/phabricator/article/configuring_accounts_and_registration/

执行该语句就可以再次登录啦。

phabricator/ $ ./bin/auth recover <username>
在下图位置加上账号密码登录方式。


解决问题:

每个人的问题可能不同,phabricator功能很完善,有什么问题都会详细的讲清楚。

Small MySQL "max_allowed_packet"

先看mysql该字段的大小

mysql> show VARIABLES like '%max_allowed_packet%';
+--------------------------+------------+
| Variable_name            | Value      |
+--------------------------+------------+
| max_allowed_packet       | 4194304    |
| slave_max_allowed_packet | 1073741824 |
+--------------------------+------------+

方法:查找mysql配置文件

[root@localhost etc]# mysql --help | grep my.cnforder of preference, my.cnf, $MYSQL_TCP_PORT,
/etc/my.cnf /etc/mysql/my.cnf /usr/etc/my.cnf ~/.my.cnf 
#vim /etc/my.cnf

在my.cnf的[mysqld]段或者mysql的server配置段进行修改:max_allowed_packet = 32M

重启mysql:  service mysqld restart

tips:
启动:
1、使用 service 启动:service mysqld start
2、使用 mysqld 脚本启动:/etc/inint.d/mysqld start
3、使用 safe_mysqld 启动:safe_mysqld&
二、停止
1、使用 service 启动:service mysqld stop
2、使用 mysqld 脚本启动:/etc/inint.d/mysqld stop
3、 mysqladmin shutdown
三、重启
1、 使用 service 启动:service mysqld restart
2、使用 mysqld 脚本启动:/etc/inint.d/mysqld restart
再来看该问题就解决了。
mysql> show VARIABLES like '%max_allowed_packet%';
+--------------------------+------------+
| Variable_name            | Value      |
+--------------------------+------------+
| max_allowed_packet       | 33554432   |
| slave_max_allowed_packet | 1073741824 |
+--------------------------+------------+

MySQL STRICT_ALL_TABLES Mode Not Set

在数据库主机“localhost”上,全局sql_mode未设置为STRICT_ALL_TABLES。强烈建议您在运行Phabricator时启用此模式。 默认情况下,MySQL会默默忽略某些类型的错误,这可能会导致数据丢失并引发安全问题。启用严格模式会导致MySQL提出明确的错误,并阻止整个类别的问题造成任何损害。 您可以在MySQL手册中找到关于此模式的更多信息(以及如何配置它)。通常,将它添加到my.cnf文件(在[mysqld]部分),然后重新启动mysqld就足够了:

(请注意,如果您针对同一个数据库运行其他应用程序,则它们可能无法在严格模式下运行。在这些情况下,请小心启用它。)



Zend OPcache没有安装

(网上有些在php.ini中加.dll后缀的,扩在目录是ext,这种是在windows下执行的。)

之前已经下载过扩展了

 yum install php-extname 

现在要做的是增加扩展

首先,到你php解压目录下

cd /twy/php/php-5.6.30/ext/ 

该目录下是所有的扩展


cd进入opcache的目录,调用phpize程序生成编译配置文件

[root@localhost opcache]# /usr/local/php-5.6.30/bin/phpize 
Configuring for:
PHP Api Version:         20131106
Zend Module Api No:      20131226
Zend Extension Api No:   220131226
[root@localhost opcache]# ./configure --with-php-config=/usr/local/php-5.6.30/bin/php-config

编译扩展库,分别执行下面的configure和make命令

[root@localhost opcache]# ./configure --with-php-config=/usr/local/php-5.6.30/bin/php-config
[root@localhost opcache]# make
/bin/sh /twy/php/php-5.6.30/ext/opcache/libtool --mode=install cp ./opcache.la /twy/php/php-5.6.30/ext/opcache/modules
cp ./.libs/opcache.so /twy/php/php-5.6.30/ext/opcache/modules/opcache.so
cp ./.libs/opcache.lai /twy/php/php-5.6.30/ext/opcache/modules/opcache.la
cp ./.libs/opcache.a /twy/php/php-5.6.30/ext/opcache/modules/opcache.a
chmod 644 /twy/php/php-5.6.30/ext/opcache/modules/opcache.a
ranlib /twy/php/php-5.6.30/ext/opcache/modules/opcache.a
libtool: install: warning: remember to run `libtool --finish /twy/php/php-5.6.30/modules'Build complete.
Don't forget to run 'make test'.

make成功执行后,生成的扩展库文件在当前目录的 modules 子目录下,


创建extension_dir的目录,将编译好的扩展文件复制到extension下面
cp /twy/php/php-5.6.30/ext/opcache/modules/opcache.so  /usr/lib64/php/modules

编辑php.ini

vim /usr/local/php-5.6.30/lib/php.ini

extension_dir = "/usr/lib64/php/modules"   //你建的扩展文件夹

在[opcache]下

添加 

zend_extension=php_opcache.so

去掉注释(如果有哪里没修改对。phabricator会告知)

opcache.enable=1

opcache.enable_cli=0

opcache.memory_consumption=64

opcache.validate_timestamps=0


PHP Extension "APCu" Not Installed


PHP 以前的版本有扩展 apc,apc缓存分为系统缓存和用户缓存。
php5.5以后,opcache将代替apc做为php加速的位置,也就是代替其系统缓存的位置。
用户缓存功能独立出来,开启新的组件,这个组件名称叫做apcu。

所以这两个扩展不冲突。

yum  install gcc make autoconf pkg config
如果没安装PECL先安装

# yum install php-pear
安装apcu
pecl install apcu-4.0.11

(执行这条命令是遇到报错Can't find PHP headers in /usr/include/php

The php-devel package is required for use of this command

yum install php-devel 解决)

这两步直接enter

Enable full APC compatibility [yes] : 
Enable internal debugging in APCu [no] : 
安装后的提示信息
Build process completed successfully
Installing '/usr/lib64/php/modules/apcu.so'
Installing '/usr/include/php/ext/apcu/apc.h'
Installing '/usr/include/php/ext/apcu/apc_api.h'
Installing '/usr/include/php/ext/apcu/apc_cache_api.h'
Installing '/usr/include/php/ext/apcu/apc_lock_api.h'
Installing '/usr/include/php/ext/apcu/apc_pool_api.h'
Installing '/usr/include/php/ext/apcu/apc_sma_api.h'
Installing '/usr/include/php/ext/apcu/apc_bin_api.h'
Installing '/usr/include/php/ext/apcu/apc_serializer.h'
install ok: channel://pecl.php.net/apcu-4.0.11
configuration option "php_ini" is not set to php.ini location
You should add "extension=apcu.so" to php.ini

php的mysql扩展不能用

EXCEPTION: (Exception) About to call mysql_connect(), but the PHP MySQL extension is not available

平常我们都是先安装mysql,然后才能去安装php。假如先安装php,后安装mysql,由于php需要连接mysql,因而在php引擎中需要配置使用mysql.so扩展。这时需要手动编译生成mysql.so扩展。使用phpize工具能够生成mysql.so,但是必须加上"--with-mysql=mysql客户端的路径"。也就是mysql.so模块必须用到mysql客户端才行。

可以这样理解,mysql.so内部会调用mysql客户端,以便实现连接mysql数据库服务器。
我们常常用到的mysql_connect()可能就是调用了mysql客户端才能完成连接数据库的操作。

1.进入Php的安装包mysql源码的位置

[root@localhost mysql]#cd /twy/php/php-5.6.30/ext/mysql
[root@localhost mysql]#/usr/local/php-5.6.30/bin/phpize
[root@localhost mysql]#./configure --with-php-config=/usr/local/php-5.6.30/bin/php-config --with-mysql --with-zlib-dir=/usr/local/lib
[root@localhost mysql]#make
[root@localhost mysql]#make install

tips:

/usr/local/lib/php/extensions/no-debug-non-zts-20090626/ 为php扩展的动态库存放目录

--with-mysql="填mysql的安装目录“ 但是我这里空着了,是因为填了会报找不到mysql头文件,虽然这个安装目录中有头文件,之后查到:

--with-mysql=/usr/include/mysql,这个参数应该不对,把它改为--with-mysql 或--with-mysql=/usr。因为MYSQL是RPM装的,按系统路径来的。找不到头文件估计多半是64位的问题,在64位上装软件遇到的问题,很多时候都是因为库路径的问题,按dongboemil应该是可以解决的。要么PHP指定预配置参数MYSQL的库路径,要么就是把MYSQL的库复制或软链接到PHP默认寻找的目录。

https://www.cnblogs.com/wangjinke/p/6019285.html

当你加了扩展后PHP还是不能连接mysql,请参考如下链接的内容,在mysql的my.cnf中的[mysql]段中加入:  protocol=tcp

http://www.jb51.net/article/54025.htm

安装php扩展mysqlnd,报错Cannot find OpenSSL's <evp.h>

https://www.jianshu.com/p/2ae07941d84e

安装mysqlnd.so执行如下命令

 /usr/local/php-5.6.30/bin/phpize

 export PHP_OPENSSL_DIR=yes

./configure --with-php-config=/usr/local/php-5.6.30/bin/php-config

make

cp modules/mysqlnd.so  /usr/lib64/php/modules








这篇关于【phabricator】代码审查工具issue的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/794108

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

Java数字转换工具类NumberUtil的使用

《Java数字转换工具类NumberUtil的使用》NumberUtil是一个功能强大的Java工具类,用于处理数字的各种操作,包括数值运算、格式化、随机数生成和数值判断,下面就来介绍一下Number... 目录一、NumberUtil类概述二、主要功能介绍1. 数值运算2. 格式化3. 数值判断4. 随机

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

Java实现状态模式的示例代码

《Java实现状态模式的示例代码》状态模式是一种行为型设计模式,允许对象根据其内部状态改变行为,本文主要介绍了Java实现状态模式的示例代码,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来... 目录一、简介1、定义2、状态模式的结构二、Java实现案例1、电灯开关状态案例2、番茄工作法状态案例