0

0

数据库运维开发环境的调试模式演进

蓮花仙者

蓮花仙者

发布时间:2025-07-15 09:18:01

|

306人浏览过

|

来源于php中文网

原创

这是学习笔记的第2393篇文章。

昨日,同事反馈了一个问题,原本的办公机环境中的虚拟机可以将办公机的IP暴露出来,提供数据库运维的API服务。例如,办公机的IP为192.168.10.100,而使用VirtualBox的虚拟机采用主机模式,其IP可能为192.168.56.100,那么192.168.56.100上的API服务可以通过192.168.10.100进行访问。通常,开发环境测试完成后,代码会被推送到GitLab,经过验证后发布。因此,测试和线上环境都有各自的相关服务,IP方式模式相对固定。

数据库运维开发环境的调试模式演进

听起来这似乎是一个简单的问题,但最近这种多服务间的联调模式出现了问题,如上图红色部分所示。如果使用桥接模式的IP,网络那边有明确的限制,也不可行,因此原本简单粗暴的测试联调需要转换思路。

我们考虑了一种新思路,即申请一台新的Linux服务器,保持与线上一致的环境,并开启桌面模式。这样,办公机可以通过VNC等方式连接到Linux服务器,然后在Linux下进行开发和测试,提交代码变更。这听起来是个不错的主意,而且统一的Linux环境还可以共享基础配置,避免了许多人重复配置环境的烦恼。整体设计如下图所示:

数据库运维开发环境的调试模式演进

然而,这种模式存在一些问题。其中一个问题是测试Linux服务器上的代码时,每个人分别测试,但提交是个问题。如果要最大限度地保证效率,可能每个人都可以向主分支提交代码,这样会导致混乱,而且一旦发现冲突,就需要一个统一的角色来合并。此外,远程桌面的办公模式相对可行,但如果网络不够好,体验会很糟糕。退一步讲,本机开发的效率肯定是最方便最高效的。

期间我们也讨论了申请一台统一的Windows服务器,但由于Python依赖库的差异,我们无法确认在Windows上正常运行的服务是否在Linux上完全可用,因此这个方案很快被我们放弃了。

还有一种模式是我们在办公机上开发逻辑,假设通过某种机制将变更的代码先推送到开发服务器(Linux)上,那么这个服务就是一个相对固定的访问模式。如果开发联调中出现问题,可以不断调整,直到满足业务场景的测试。问题是,有什么机制可以保证我们可以随时将代码同步发布到IDC的开发服务器,如下图红色部分所示:

数据库运维开发环境的调试模式演进

此时,我们想到了几种潜在的解决方案:

SmartB2B行业电子商务
SmartB2B行业电子商务

SmartB2B 是一款基于PHP、MySQL、Smarty的B2B行业电子商务网站管理系统,系统提供了供求模型、企业模型、产品模型、人才招聘模型、资讯模型等模块,适用于想在行业里取得领先地位的企业快速假设B2B网站,可以运行于Linux与Windows等多重服务器环境,安装方便,使用灵活。 系统使用当前流行的PHP语言开发,以MySQL为数据库,采用B/S架构,MVC模式开发。融入了模型化、模板

下载

1)第一种,使用Filezilla在办公机上进行文件传输,也算是一种快速发布模式。

2)第二种,在办公机上配置一个bat脚本,实现从虚拟机上下载文件,然后推送到测试环境。

虽然这些方法都可行,但感觉流程还是缺少了一些东西,因此我们继续思考,提出了下面的方案,即在IDC测试服务器上配置一个WEB文件服务。默认的Python文件服务只需一条命令,但我们需要做一些额外的工作,即保证WEB文件服务可以上传文件,因此需要简单编写一个Python脚本来实现。改进后的方案如下:

数据库运维开发环境的调试模式演进

这种方案的好处是我们可以制定策略,满足个性化的配置和快速发布。例如,有A、B、C三个人,他们可以在IDC测试服务器上使用不同的目录和不同的WEB文件服务,例如:

A,配置7001的API端口,配置9001的WEB文件服务。

B,配置7002的API端口,配置9002的WEB文件服务。

C,配置7003的API端口,配置9003的WEB文件服务。

如此一来,经过测试,整个过程可以随意发布和测试,且对其他人没有直接影响。测试后的代码可以根据测试情况提交,合并到主分支。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

755

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

636

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

759

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

618

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1262

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

577

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

707

2023.08.11

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

8

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.2万人学习

Git 教程
Git 教程

共21课时 | 2.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号