检测服务器环境,实现快速部署。适用于CRMEB_PRO/多店

news2024/11/17 6:37:32

运行效果如图:

241b4202311271112504772.png

最近被好多人问,本来运行的好好的,突然swoole就启动不了了。

本工具为爱发电,如果工具正好解决了您的需求。我会很开心

代码如下:

"""
    本脚本为爱发电
    by:网前雨刮器
"""
import subprocess
import re

def check_php_environment():
    def check_php_version():
        try:
            output = subprocess.check_output(['php', '-v'], stderr=subprocess.STDOUT)
            result = output.decode('utf-8')
            php_version_str = result.split('\n')[0]
            php_version = php_version_str.lower().split(' ')[1]

            if php_version.startswith('7.'):
                major_version, minor_version, patch_version = map(int, php_version.split('.'))
                if 7 <= major_version <= 7 and 1 <= minor_version <= 4:
                    print(f"\033[32mPHP版本通过 (当前版本:{php_version})\033[0m")
                else:
                    print(f"\033[31mPHP版本不通过 (当前版本:{php_version})\033[0m")
            else:
                print(f"\033[31mPHP版本不通过 (当前版本:{php_version})\033[0m")

        except subprocess.CalledProcessError as e:
            return None

    def check_php_extension(extension_name, expected_version=None):
        try:
            output = subprocess.check_output(['php', '-m'], stderr=subprocess.STDOUT)
            result = output.decode('utf-8')
            installed_extensions = result.split()

            if extension_name in installed_extensions:
                print(f"\033[32m{extension_name} 已安装\033[0m")

                if expected_version is not None:
                    output = subprocess.check_output(['php', '--ri', extension_name], stderr=subprocess.STDOUT)
                    result = output.decode('utf-8')

                    match = re.search(r"Version => (.+)", result)
                    if match:
                        version = match.group(1).strip()
                        print(f"\033[32m{extension_name} 版本号为 {version}\033[0m")

                        if not re.match(expected_version.replace("*", r"\d+"), version):
                            return None
                            # print(f"报错:{extension_name} 扩展的版本号不满足要求")
                    else:
                        return None
                        #print(f"无法获取 {extension_name} 扩展的版本信息")
            else:
                print(f"\033[31m{extension_name} 扩展未安装\033[0m")

        except subprocess.CalledProcessError as e:
            print(f"无法执行命令: {e.output}")

    def check_proc_open():
        try:
            output = subprocess.check_output(['php', '-i'], stderr=subprocess.STDOUT)
            result = output.decode('utf-8')

            if 'disable_functions' in result:
                disable_functions = result.split('disable_functions => ')[1].split(' =>')[0]
                if 'proc_open' in disable_functions:
                    print("\033[31mproc_open 函数已被禁用\033[0m")
                else:
                    print("\033[32mproc_open 函数未被禁用\033[0m")
            else:
                print("无法获取禁用函数列表")

        except subprocess.CalledProcessError as e:
            print(f"无法执行命令: {e.output}")
    
    def check_mysql_version():
        try:
            output = subprocess.check_output(['mysql', '-V'], stderr=subprocess.STDOUT)
            result = output.decode('utf-8')
            version_match = re.search(r"\d+\.\d+\.\d+", result)
            if version_match:
                mysql_version = version_match.group(0)
                if mysql_version.startswith('5.6.') or mysql_version.startswith('5.7.'):
                    print(f"\033[32mMySQL 版本通过 (当前版本:{mysql_version})\033[0m")
                else:
                    print(f"\033[31mMySQL 版本不通过 (当前版本:{mysql_version})\033[0m")
            else:
                print("\033[31m无法获取MySQL 版本号\033[0m")
    
        except subprocess.CalledProcessError as e:
            print(f"无法执行命令: {e.output}")

    def check_web_server():
        try:
            apache_process = subprocess.check_output(['ps', '-ef']).decode('utf-8')
            if 'apache2' in apache_process or 'httpd' in apache_process:
                print("\033[32m当前环境为 Apache  (建议使用Nginx)\033[0m")
                return
    
            nginx_process = subprocess.check_output(['ps', '-ef']).decode('utf-8')
            if 'nginx' in nginx_process:
                print("\033[32m当前环境为 Nginx\033[0m")
                return
    
            print("\033[31m未检测到 Apache 或 Nginx 进程\033[0m")
    
        except subprocess.CalledProcessError as e:
            print(f"无法执行命令: {e.output}")


    print('')
    check_php_version()
    print('')
    check_proc_open()
    print('')
    check_php_extension('redis')
    print('')
    check_php_extension('fileinfo')
    print('')
    check_php_extension('swoole')
    print('')
    check_php_extension('swoole_loader', '3.0.\d+')
    print('')
    check_mysql_version()
    print('')
    check_web_server()
    print('')
    print('---------------------------------------------------------------------------------')
    print('')
    print("\033[33m注:请确定当前PHP命令行版本与你安装的PHP版本一致\033[0m")
    print("\033[33m注:如果你确定以上扩展已经安装并配置,请重启php、必要时重启服务器\033[0m")
    print("\033[33m本脚本为爱发电\033[0m")
    print("\033[33mby:网前雨刮器\033[0m")
    
check_php_environment()

如果您不会使用python 不会配置python环境,可以使用我已经打包好的程序

使用方法如下:

将程序放在服务器下,直接“./文件名” 运行即可。

982b9202311271116187887.png

​​​​​​​ 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1665342.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

共享云桌面如何助力企业信息化和数字化?

随着科技的飞速发展&#xff0c;信息化和数字化已经成为企业转型的重要方向。共享云桌面作为一种新兴的信息化工具&#xff0c;正以其独特的优势助力企业实现信息化和数字化的目标。本文将详细探讨共享云桌面如何助力企业信息化和数字化的过程&#xff0c;以及它所带来的效益。…

学习网络安全现在还有前景吗?行业分析报告

如果你现阶段选择入行网络安全&#xff0c;就相当于10年前学IT&#xff0c;当它发展起来的时候&#xff0c;你刚好遇到行业红利期。 网络安全这个职业完全可以改变很多人的人生轨迹。 因为它是个不需要你有多强大的情商&#xff0c;不需要你去学习更多复杂的职场和人际关系技…

2024年618值得安利的数码好物有哪些?年度值得入手的数码清单分享

随着2024年618购物节的到来&#xff0c;各类数码好物纷至沓来&#xff0c;为消费者提供了丰富多样的选择&#xff0c;在这个充满诱惑的购物狂欢中&#xff0c;哪些数码产品值得我们重点关注和入手呢&#xff1f;接下来就让我们一起探索这份年度值得入手的数码清单&#xff0c;分…

图鸟模板-官网:基于Vue 3的前端开发新篇章

一、引言 随着前端技术的飞速发展&#xff0c;企业对于官网的需求也从简单的展示型网站向功能丰富、交互体验良好的方向转变。在这样的背景下&#xff0c;图鸟模板-官网以其基于Vue 3的纯前端开发特性&#xff0c;以及支持微信小程序、支付宝小程序、APP和H5的跨平台能力&…

【贪心算法】哈夫曼编码Python实现

文章目录 [toc]哈夫曼编码不同编码方式对比前缀码构造哈夫曼编码哈夫曼算法的正确性贪心选择性质证明 最优子结构性质证明 总结 Python实现时间复杂性 哈夫曼编码 哈夫曼编码是广泛用于数据文件压缩的十分有效的编码方法&#xff0c;其压缩率通常为 20 % 20\% 20%到 90 % 90\%…

RK3568 学习笔记 : Linux emmc 内核启动 rootfs 根文件系统无法正常挂载问题的分析

问题描述 平台 &#xff1a; NanoPi-R5C 开发板 RK3568 平台。 手动编译的 Linux 内核&#xff0c;结果发现大概率 emmc 无法正常初始化&#xff0c;导致 rootfs 根文件系统无法正常挂载 Linux 内核版本&#xff1a; 6.1 Linux 内核代码位置&#xff1a; https://github.com…

Github图片显示不出来?两步解决!

很多同学可能和我一样&#xff0c;在GitHub中找一些项目或者资料的时候&#xff1b;总是会看到一些图片显示不出来&#xff0c;或者数学公式乱码&#xff1a; 比如这样 还有这样 其实这个主要是因为DNS污染导致的&#xff0c;具体大家可以百度&#xff0c;这边不详细介绍。 解决…

Java入门基础学习笔记4——开发Helloworld入门程序

Java程序开发的三个步骤&#xff1a; 1&#xff09;编写代码 2&#xff09;编译代码 3&#xff09;运行代码 注意事项&#xff1a; 第一个java程序建议使用记事本来编写。 建议代码文件名全英文、首字母大写、满足驼峰模式&#xff0c;源代码文件的后缀必须是.java 注意&a…

37 | 什么时候会使用内部临时表?

union 执行流程 (select 1000 as f) union (select id from t1 order by id desc limit 2);key=PRIMARY,说明第二个子句用到了索引 id。 Extra 字段,表示在对子查询的结果集做 union 的时候,使用了临时表 (Using temporary)。 执行流程 创建一个内存临时表,这个临时表只有…

OpenAI 人工智能搜索产品即将推出,文本和图像都支持?!

OpenAI 人工智能搜索产品即将推出 OpenAI 计划于下周一(5 月 13 日)正式公布其人工智能搜索产品,不过报道中强调具体公告日期可能发生变化。OpenAI 拒绝对路透社的报道置评。外媒 The Information 在今年 2 月的报道中指出,OpenAI 一直在秘密开发其自家网络搜索服务,并将获…

LeetCode例题讲解:844.比较含退格的字符串

给定 s 和 t 两个字符串&#xff0c;当它们分别被输入到空白的文本编辑器后&#xff0c;如果两者相等&#xff0c;返回 true 。# 代表退格字符。 注意&#xff1a;如果对空文本输入退格字符&#xff0c;文本继续为空。 示例 1&#xff1a; 输入&#xff1a;s "ab#c&qu…

网站实现微信扫码登录(利用微信开放平台实现)

第一步&#xff1a;微信开放平台账户申请 网址&#xff1a;微信开放平台 1.首先我们要做的就是进入到微信开放平台申请一个开放平台账户&#xff0c;获得资质&#xff01; &#xff1a;注册需要准备营业执照、1-2个工作日审批、300元认证费 &#xff1a;注册之后&#xff0…

Window逆向基础之逆向工程介绍

逆向工程 以设计方法学为指导&#xff0c;以现代设计理论、方法、技术为基础&#xff0c;运用各种专业人员的工程设计经验、知识和创新思维&#xff0c;对已有产品进行解剖、深化和再创造。 逆向工程不仅仅在计算机行业、各行各业都存在逆向工程。 计算机行业逆向工程 计算…

裸金属服务器与云服务器有什么区别?

近年来&#xff0c;随着云计算技术的迅速发展&#xff0c;裸金属和云服务器已成为企业部署业务的两种主要方式。 裸金属是指提供基础设施硬件环境&#xff0c;但不包含操作系统和中间件的计算资源服务。 而云服务器则是通过虚拟化技术将计算资源划分为多个虚拟机&#xff0c;可…

JDK1.8 安装并配置环境变量

一、Windows 配置 1 安装文件 jdk-8u401-windows-i586.exe 2 环境变量 JAVA_HOME C:\Program Files (x86)\Java\jdk-1.8 CLASSPATH .;%JAVA_HOME%\lib\tools.jar;%JAVA_HOME%\lib\dt.jar; Path %JAVA_HOME%\bin 说明&#xff1a;Win7/Win8 中 Path 可能需要写成 ;%JAVA_HO…

【excel】统计单元格内数字/字符串的数量

文章目录 一、问题二、步骤&#xff08;一&#xff09;将A1中的数字分解出来&#xff0c;在不同的单元格中显示&#xff08;二&#xff09;统计每个数字出现的个数&#xff08;三&#xff09;去重 三、尾巴 一、问题 单元格中有如下数值&#xff1a;12345234534545&#xff0c…

01 背包(从二维数组到一维滚动数组)

问题描述&#xff1a; 有n件物品和一个最多能背重量为w 的背包。第i件物品的重量是weight[i]&#xff0c;得到的价值是value[i] 。每件物品只能用一次&#xff0c;求解将哪些)物品装入背包里物品价值总和最大。 二维dp数组01背包 1. 确定dp数组以及下标的含义 dp[i][j] 表…

Stable Diffusion写真完整教程

前言 最近自己对AI非常痴迷&#xff0c;并且今后也会一直在这个领域深耕&#xff0c;所以就想着先入门&#xff0c;因此花时间研究了一番&#xff0c;还好&#xff0c;出了点小成果&#xff0c;接下来给大家汇报一下。 AI绘画 提到AI绘画&#xff0c;大家可能立马会想到made…

男款内裤哪个品牌最好?男士内裤高能测评,选购攻略分享!

很多男性朋友的内裤都是穿到天荒地老的存在&#xff0c;但实际上如果一条内裤没有定期更换的话&#xff0c;存在的细菌就难以消除&#xff0c;从而可能导致出现健康问题&#xff0c;而且一条内裤没有定期更换&#xff0c;舒适性和透气性等方面都非常差&#xff01; 定期更换内裤…

AI 入门:从 ChatGPT 开始

在信息泛滥的时代&#xff0c;AI 技术已经渗透到生活的各个方面&#xff0c;学习 AI 成为个人发展的必然趋势。而 ChatGPT 作为 AI 领域的佼佼者&#xff0c;无疑是开启学习之旅的最佳起点。它不仅提供了一个便捷的交流平台&#xff0c;更能显著提升信息处理效率。 本文将带领…