php python整合_GitHub - liuzhen153/php-python: 用PHP调用Python程序,实用且非常容易地集成到你的PHP项目中。...

更新日志

继承指定文件夹里的模块 -- 2017-05-11

新增LOAD_TYPE,可以动态加载包,不需要每次都重启ppython服务 -- 2017-09-22

新增日志记录,脚本控制启动/重启/停止,支持supervisor管理ppython进程 -- 2019-03-29

优化日志记录方式,新增ipv 6 支持,且不再将python部分放入项目代码库,应单独管理 -- 2019-04-03

更新使用说明,明确表示ppython没问题,不会导致请求发送两次。

终于将内奸揪了出来

1. 如果在调用ppython时,最后PHP有打印形式的输出,则对应的python脚本会被执行两遍,这也是为什么日志打印两遍的原因,目前未找到解决方法。

导致请求两次的内奸终于找到了: 原来是chrome上的jsonView jsonViewer json formatter 格式化插件导致get请求会发送两次ಥ_ಥ。停用该插件即可!

jsonview.png

令人惊喜的更新

利用ppython.sh 来替换screen或tmux

请注意:这种方式和supervisor互斥

# 开启ppython服务

sh ppython/ppython.sh

# 停止ppython服务

sh ppython/ppython.sh stop

所有重要信息都会被记录在日志里 ppython/log/python/all.log ,默认按天进行分割,保留最近10天日志,追错/排查不再抓瞎

ppythonlog.png

强烈建议使用supervisor来管理你的ppython服务

supervisor简介

C/S架构的进程控制系统,可使用户在类UNIX系统中监控、管理进程。常用于管理与某个用户或项目相关的进程。

官网地址:http://www.supervisord.org

组成部分

supervisord:服务守护进程

supervisorctl:命令行客户端

Web Server:提供与supervisorctl功能相当的WEB操作界面

XML-RPC Interface:XML-RPC接口

使用方法

安装supervisor

# 注意,supervisor不支持python3,如果你默认是python3请使用pip2 isntall supervisor来安装

pip install supervisor

修改配置文件

①在supervisor/supervisord.conf搜索 /Users/liuzhen20/work/2019/php-python/ppython/ ,然后将这几处替换成你的ppython所在位置

②修改supervisor/supervisord.conf第22~25行

[inet_http_server] ; inet (TCP) server disabled by default

port=127.0.0.1:8886 ; 这里改为你的IP地址和端口

username=admin ; 默认用户名

password=admin2019 ; 默认密码

③在supervisor/ppython.ini搜索 /Users/liuzhen20/work/2019/php-python/ppython/ ,然后将这几处替换成你的ppython所在位置

启动服务

sh ppython/supervisord/super_update.sh

访问服务

super.png

Enjoy it!

一、ppython 简述

本类库基于年久已不再维护的ppython改写,为了表达对它的敬意,我决定沿用原名称。

站在巨人的肩膀上

ppython是一个令人兴奋的项目,但是已经在14年停止维护和更新。以下部分文字摘自原ppython介绍,原文地址 http://www.oschina.net/p/ppython

许多人在纠结WEB快速开发究竟是采用PHP,还是采用Python,二者同样是脚本语言,但特点鲜明:

PHP: Web专用开发利器,有10多年的经验积累,但其他领域基本不涉及,扩展性不强,企业应用少。

Python: 近期的明星语言,面向对象、简单高效、可扩展性强,但Web开发积累少,成熟度低。

ppython开源项目既是结合使用PHP和Python两种语言,取其所长、补其所短,面向企业WEB领域的开发技术。此技术可以理解为PHP和Python相结合的技术,也可称为PHP和Python混合编程技术,或者PHP调用Python服务的技术,也有人习惯称之为前台PHP后台Python的技术框架。

本项目是LAJP项目的语言环境的拓展,变化是将LAJP中的Java语言变更为Python语言,因此LAJP的技术、文档对本项目有参考作用。

特点

优势互补: PHP和Python都是流行的脚本语言,PHP非常适合网页编程;而Python可以当作轻量级JAVA,二者结合可发挥各自优势。

高效稳定: Apache+PHP组合可带来优异的WEB服务稳定性,而Python的语言能力可补充如连接池、事物管理、分布式、对象模型等高端特性。

通信机制: PHP和Python间的通讯方式采用TCP Socket和Unix Socket两种机制,兼顾通讯效率和分布式。

数据类型自动转换机制: PHP数据和Python数据可准确地自动匹配和转换,无须程序员编写解析代码。

易用: 安装配置简单,PHP端和Python端编程符合各自的编程习惯。

轻量级: 架构非常轻量级,除了最基本的PHP和Python环境,不需要任何扩充的、第三方的组件、容器。

PHP和Python的互通:

687474703a2f2f7374617469632e6f736368696e612e6e65742f75706c6f6164732f696d672f3230313330392f31393038323332365f413253702e706e67

提高Python的多线程效率

Python因其语言GIL特性,多线程效率不高。在PHP+Python的混搭机制中,Python端可以多进程方式部署,从而提高Python的整体工作效率。

新ppython可以做什么?有什么优势?

相对于已经年久失修且各种报错的旧版ppython,我做了相应的优化和修正,您可以很容易的集成在任意PHP项目中!

新的ppython主要改进了以下内容:

将原生代码封装成可供调用的类库,开发者不需要关注深入的代码逻辑即可方便的使用;

改正了原项目中很多错误,精简了代码,去除无用代码;

将方法调用逻辑优化,从只传入文件名改为默认需传入文件夹/文件名,这样使开发者可以更好的管理Python文件;

注意事项

确保PHP已经打开socket相关模块

确保你的服务器上有Python3及以上版本

二、使用方法(以ThinkPHP5为例)

类库端的操作

克隆代码放到example的extend目录下。

在python目录下新建文件目录和文件,例:test/test.py。

python文件的基本写法和以前没有区别,其实就是将对外部访问的部分封装成方法,最终要将结果返回一个字符串或数组。

在test.py中写入你要调用的方法,例:

# 无参数

def hello():

return 'Hi , Tommy'

# 传递参数

def hello_name(name):

return 'Hi , ' + name

# 返回数组

def return_arr():

user = {}

user['name'] = 'Tommy'

user['age'] = 24

return user

# 由于PHP传过来的参数都会被处理成字符串类型,所以需要使用数字类型的地方请自行转换,如若是其他类型数据做类似处理,否则会报错。

# 但是由Python传给PHP的结果的数据类型不受限制

def dosum(num1 , num2):

return int(num1) + int(num2)

使用终端用python3运行类库下的php_python.py文件

python3 php_python.py

看到以下输出,证明启动成功

-------------------------------------------

- PPython Service

- Time: 2017-08-04 13:24:13

-------------------------------------------

Listen port: 21230

charset: utf-8

Server startup...

在控制器中如何使用

头部要引用该类库

use ppython\Ppython;

示例代码

<?php

namespace app\index\controller;

use ppython\Ppython;

class Index

{

// 不带参数

public function py()

{

$python = new Ppython();

$data = $python->py("sayhi.hi::hello");

dump($data);

}

//带参数的方法

public function py_with_something($name)

{

$python = new Ppython();

// 更多参数依次往后添加

$data = $python->py("sayhi.hi::hello_name",$name);

dump($data);

}

// python返回的是数组

public function py_arr()

{

$python = new Ppython();

$data = $python->py("sayhi.hi::return_arr");

dump($data);

}

// PHP传递数字类型变量,计算2+3的和

public function py_num()

{

$python = new Ppython();

$data = $python->py("sayhi.hi::dosum",2,3);

dump($data);

}

}

访问以查看效果

开启服务器,将根目录指向example的public下。

访问不带参数的方法

http://localhost/index/index/py

直接会得到结果

string(10) "Hi , Tommy"

访问带参数的方法,可以依次将参数跟在方法后面

http://localhost/index/index/py_with_something/name/Handsom_Tommy

经过Python处理后得到结果(多参数的情况按照说明使用即可)

string(18) "Hi , Handsom_Tommy"

Python返回给PHP的结果不受限制,我们来测试下返回一个数组

http://localhost/index/index/py_arr

得到相应数组

array(2) {

["name"] => string(5) "Tommy"

["age"] => int(24)

}

由于PHP传过来的参数都会被处理成字符串类型,所以需要使用数字类型的地方请自行转换,如若是其他类型数据做类似处理,否则会报错。

http://localhost/index/index/py_num

得到以下结果,Python返回给PHP的数据类型不受限制

int(5)

三、一些必要的操作和注意事项

必须使php_python.py一直运行着

使用本类库必须进行服务器端的相关操作,其实是起socket服务,以支持PHP和Python之间的通信。

从上面已经可以看到,必须要让php_python.py运行着,这个类库才能正常使用,因此我们需要在服务器端进行一些必要的操作。我只提供思路和自己的解决办法,如果您有更好的解决方法,请联系我。

解决方案原理: 当我们断开SSH连接时,依然保持该文件的运行状态。

利用screen或tmux这类工具运行php_python.py,这样我们断开SSH连接也没关系,它会在后台继续运行。这类工具具体使用方法请自行搜索。

GOOD NEWS!

现在支持自管理脚本/supervisor进程管理啦!详情请看最上面【令人惊喜的更新】

如果在已有文件中添加新的代码,必须先ctrl + c来shutdown上述php_python.py文件,然后重新运行该文件。否则,新添加的代码不起效果。

但是,如果是新添加了目录或文件,不用进行重启操作。

GOOD NEWS!

现在支持LOAD_TYPE设置啦!你可以在process.py里指定LOAD_TYPE的值。

默认为0,即原有模式:如果在已有文件中添加新的代码,必须先ctrl + c来shutdown上述php_python.py文件,然后重新运行该文件。否则,新添加的代码不起效果。

1为reload模式,此时可以动态加载模块,修改代码不必再重启ppython服务

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值