• 部署GitLab服务器

部署GitLab服务器

2025-04-26 11:51:25 1 阅读

文章目录

    • 环境准备
    • GitLab
    • 部署GitLab服务器
    • GitLab中主要的概念
    • 客户端上传代码到gitlab服务器
    • CI-CD概述
      • 软件程序上线流程
      • 安装Jenkins服务器
    • 配置jenkins
    • 软件版本管理
    • 配置jenkins访问gitlab远程仓库
    • 下载到子目录
    • 部署代码到web服务器
      • 自动化部署流程
    • 配置共享服务器
      • 配置jenkins把gitlab下载的代码打包
    • web服务自动部署
      • 编写自动上线脚本

环境准备

  • 本实验采用华为云ECS进行,模拟真实工作环境
  • 当然本地电脑环境配置达标,也可以在本地电脑使用VMware虚拟机完成
  • 本实验供需4台云主机,全部使用Rocky Linux8.5操作系统,2vCPU,4G内存
  • 具体要求如下:
主机名IP地址配置角色
windows程序员
develop192.168.0.10|公网IP2vCPU,4G内存程序员
gitlab192.168.0.20|公网IP2vCPU,4G内存远程仓库
jenkins192.168.0.30|公网IP2vCPU,4G内存CI/CD服务器
web1192.168.0.40|公网IP2vCPU,4G内存web服务器

项目架构图

GitLab

  • 它是一个开源的git仓库服务器。用于实现代码集中托管

  • 分为企业版和CE社区版

  • 部署方式:软件包部署、容器部署

部署GitLab服务器

  • 云主机192.168.0.20,远程连接时需要连接其对应的公网IP地址
  • 将2024-AI大模型Java全链路工程师环境资料/第四模块/gitlab_zh.tar拷贝到gitlab服务器的/root
  • 将2024-AI大模型Java全链路工程师环境资料/第四模块/docker文件夹拷贝到gitlab服务器的/root
  • 通过容器部署GitLab服务
[root@gitlab ~]# cd /root/docker
[root@gitlab docker]# dnf -y localinstall *.rpm			#安装容器管理软件docker
[root@gitlab docker]# dnf -y install bash-completion	#安装tab键(刷新生效)
[root@gitlab ~]# systemctl start docker 				#启动服务
[root@gitlab ~]# systemctl enable docker				#将服务设置为开机自启 

修改gitlab服务器的的sshd服务端口号为8022,因为gitlab容器也要用到22端口,有冲突。

vim +17是指打开配置文件时,光标直接定位到第17行。

[root@gitlab ~]# vim +17 /etc/ssh/sshd_config 			#修改配置文件
17 Port 8022
[root@gitlab ~]# systemctl restart sshd					#重启sshd远程管理服务
#重启之后需要使用远程工具重新连接gitlab服务器,并且指定8022端口号

gitlab容器运行需要/etc/resolv.conf文件,如果该文件已存在,则无需创建

[root@gitlab ~]# touch /etc/resolv.conf
  • 导入镜像
    • 一个镜像可以创建很多容器。镜像是只读的,容器是可以改变的。
    • 容器相当于是精简的虚拟机,可以像虚拟机一样,对外提供服务。
[root@gitlab ~]# docker load < /root/gitlab_zh.tar
[root@gitlab ~]# docker images							#查看镜像是否导入
  • 保障数据完整性
    • 为了删容器,不丢失数据,需要把容器需要的数据保存在宿主机上。
    • 在哪台主机上启动容器,哪台主机就是宿主机。
[root@gitlab ~]# mkdir -p /srv/gitlab/{config,logs,data}	#创建持久化目录
[root@gitlab ~]# ls /srv/gitlab/
config data logs
  • 创建容器
    • -d后台运行
    • -h gitlab设置容器的主机名
    • –name gitlab是docker ps查看到的容器名
    • -p指定发布的端口号,当访问宿主机443/80/22端口时,这样的请求就发给容器的相关端口
    • –restart always是开机自启
    • -v是映射路径,将容器中指定的路径,映射到宿主机,以便保存容器产生的数据
    • 最后的gitlab_zh是镜像名
[root@gitlab ~]# docker run -d -h gitlab --name gitlab -p 443:443 -p 80:80 -p 22:22 --restart always -v /srv/gitlab/config:/etc/gitlab -v /srv/gitlab/logs:/var/log/gitlab -v /srv/gitlab/data:/var/opt/gitlab gitlab_zh

[root@gitlab ~]# docker ps								#查看容器正在运行的容器
# 如果一切正常,几分钟后,可以访问http://gitlab服务器的公网ip/ (以自己为准)
# 例如:http://121.36.66.101/

附:如果容启动失败,再次创建有以下错误:

Error: error creating container storage: the container name "gitlab" is already in use by "ca425e33d7ff2给i他d282cbec1033023851cff285fe9b819ed50d47a08a875372fde". You have to remove that container to be able to reuse that name.: that name is already in use

则:

[root@gitlab ~]# docker rm gitlab
[root@gitlab ~]# docker run -d -h gitlab --name gitlab -p 443:443 -p 80:80 -p 22:22 --restart always -v /srv/gitlab/config:/etc/gitlab -v /srv/gitlab/logs:/var/log/gitlab -v /srv/gitlab/data:/var/opt/gitlab gitlab_zh

配置gitlab

  • 第一次登陆‑时,要求改密码。密码需要是复杂密码,如1234.com。修改之后,登陆的用户名是root

  • 修改外观设置

点击头像–>退出,重新登录验证

GitLab中主要的概念

  • 用户:为使用gitlab的用户创建的账号。
  • 组:用户的集合,可以为部门创建组。将来可以在项目上为组授权,组中所有的用户都会得到相应的权限。
  • 项目:用于保存代码文件的空间。
  • 用户、组、项目之间的关系如下

  • 创建用户
    • 用户名:jerry
    • 密码:1234.com

填写截图上的几项后,其他使用默认配置,点保存。

创建好用户后,点击编辑,可以为他/她设置密码:

  • 保存修改后,退出当前账号,使用新账号jerry与其密码1234.com登陆测试。

  • 第一次登陆时,也是要求修改密码,新密码可以设置与旧密码一样。

  • 新建的jerry用户因为权限较小,所以看到的界面,没有root的功能多。

  • 创建组,注意,需要使用root账号创建,这里需要切换回root账户

  • 将jerry用户加到devops组中,角色是"主程序员"

  • 创建项目,管理员root操作

  • 切换为jerry用户,查看项目是否负责

客户端上传代码到gitlab服务器

  • 查看项目路径,采用http方式上传

  • 查看项目说明

  • 在客户端develop服务器(192.168.0.10,连接其公网IP地址)上下载项目,编写代码并上传
[root@develop ~]# dnf -y install git						#安装git工具

从gitlab服务器复制地址之后,需要将gitlab单词改为自己gitlab服务器的公网IP地址

~]# git clone http://121.36.66.101/devops/myproject.git	#克隆远程仓库
[root@develop ~]# ls   								#本地出现一个myproject目录
myproject

windows客户端也可以使用git clone克隆远程仓库,提前安装git客户端(安装包在2024-AI大模型Java全链路工程师环境资料/第四模块/cicd中)

如果是刚刚安装的git软件需要首先定义全局配置,方可继续使用(执行一次即可)

git config --global user.name "jerry"
git config --global user.email "jerry@tedu.cn"

使用develop服务器编写README.txt文件,并上传至远程仓库

[root@develop ~]# cd myproject/
[root@develop myproject]# vim README.md
Welcome to my beautiful world!

[root@develop myproject]# git add .   						#保存到暂存区
[root@develop myproject]# git commit -m "init data" 		#提交至本地仓库

# 将master分支推送到origin仓库。origin是默认仓库名。
[root@develop myproject]# git push -u origin master
Username for 'http://192.168.4.20': jerry   				#用户名
Password for 'http://jerry@192.168.4.20': 1234.com   		#密码(输入不显示)
# 在服务器上刷新web页面,可以看到仓库中已经多出了README.md文件

重新操作编写代码,并提交远程仓库

# 将来就可以重得操作:写代码、确认到版本库、上传到服务器
[root@develop myproject]# cp /etc/hosts .
[root@develop myproject]# git add .
[root@develop myproject]# git commit -m "add hosts"
[root@develop myproject]# git push   						#不需要再使用-u选项
Username for 'http://192.168.4.20': jerry
Password for 'http://jerry@192.168.4.20': 1234.com			#密码(输入不显示)
# 在服务器上刷新web页面,可以看到仓库中已经多出了hosts文件

另一个客户端Windows拉取新代码,并且上传自己的代码(需要windows安装好git客户端)

$ git pull													#拉取代码
remote: Counting objects: 6, done.
remote: Compressing objects: 100% (4/4), done.
remote: Total 6 (delta 0), reused 0 (delta 0)
Unpacking objects: 100% (6/6), 515 bytes | 0 bytes/s, done.
From http://121.36.66.101/devops/myproject
 * [new branch]      master     -> origin/master

Windows本地仓库中已经多出了数据

Windows上传数据至远程仓库,编写win.txt文件,内容为"Here is Windows file."

$ git add .										#提交暂存区
$ git commit -m 'add Win.txt'					#提交本地仓库
$ git push -u origin master						#将master分支推送到origin仓库
# 在服务器上刷新web页面,可以看到仓库中已经多出了Win.txt文件

develop服务器拉取新代码,验证是否能够同步Win.txt

[root@devlop myproject]# git pull
[root@devlop myproject]# ls						#查看多出Win.txt
hosts  README.md  Win.txt
[root@devlop myproject]# cat Win.txt 			#内容正确
Here is Windows file.[root@devlop myproject]# 

CI-CD概述

  • CI:持续集成(Continuous Integration)
  • CD:持续交付(Continuous Delivery/Deployment)

软件程序上线流程

  1. 程序员将代码上传到gitlab服务器
  2. SRE工程师,通过jenkins服务器自动下载gitlab上的代码
  3. SRE工程师编写自动部署到服务器上的脚本

安装Jenkins服务器

  • jenkins服务器操作(192.168.0.30,需要远程它的公网IP地址)
# 安装依赖包
# jenkins需要通过git下载代码,所以装git。
# jenkins是java程序,所以装java
# postfix和mailx是邮件程序,jenkins可以通过它们给管理员发邮件
[root@jenkins ~]# dnf -y install  git postfix mailx java-11-openjdk
[root@jenkins ~]# ls										#查看是否上传完毕
jenkins-2.263.1-1.1.noarch.rpm jenkins_plugins.tar.gz

~]# dnf -y localinstall  jenkins-2.263.1-1.1.noarch.rpm		#安装jenkins

[root@jenkins ~]# systemctl start jenkins			#启动jenkins服务
[root@jenkins ~]# systemctl enable jenkins			#将jenkins服务设置为开机自启
[root@jenkins ~]# ss -nutlp | grep :8080			#查看端口8080是否正常
  • 访问http://jenkins服务器公网IP:8080,进行初始化
# 查看初始化密码,每个人的都不一样,请以自己的为准
[root@jenkins ~]# cat /var/lib/jenkins/secrets/initialAdminPassword
b9d26edeef714940ab10aaa541081d90

把查看到的密码粘贴到文本框中,如下:

  • 不用创建管理员,使用自带的admin

  • 修改admin密码

使用admin用户,密码123456登录jenkins

配置jenkins

  • 安装插件:jenkins的很多功能都是能过插件实现的,比如发邮件、比如中文支持
[root@jenkins ~]# tar -xf jenkins_plugins.tar.gz 

#拷贝文件的时候,注意选项,-r可以拷贝目录,-p保留权限
[root@jenkins ~]# cp -rp jenkins_plugins/* /var/lib/jenkins/plugins/

[root@jenkins ~]# systemctl restart jenkins				#重启jenkins服务
#刷新web页面,如果出现中文,则插件安装成功

软件版本管理

  • develop服务器操作
  • 可以在git中使用tag标记将某一次commit提交标识为某一版本
[root@develop ~]# cd myproject/   						#进入项目目录
[root@develop myproject]# git tag 						#查看标记,默认没有标记
[root@develop myproject]# git tag 1.0 					#将当前提交,标识为1.0
[root@develop myproject]# git tag						#查看标记
1.0
[root@develop myproject]# echo 'hello world' > index.html
[root@develop myproject]# git add .
[root@develop myproject]# git commit -m "add index.html"
[root@develop myproject]# git tag 1.1					#将当前提交,标识为1.1

# 将本地文件和tag推送到gitlab服务器
[root@develop myproject]# git push   					#只推送文件,不推送标记
[root@develop myproject]# git push --tags

在gitlab上查看标记

配置jenkins访问gitlab远程仓库

  • 新建任务

  • 参数化构建过程中,"名称"是自己定义的变量名,用于标识tag或分支

git仓库地址,在gitlab上找到myproject仓库的http地址,注意将gitlab名称改为IP地址

指定分支构建的时候,使用上面步骤创建的变量$web

  • 构建测试

在jenkins服务器查看内容,查看是否下载成功

[root@jenkins ~]# ls /var/lib/jenkins/workspace/myproject/
hosts  index.html  README.md  Win.txt

下载到子目录

  • 此时有个问题,1.1版本的代码会覆盖1.0版本的代码,无法实现多个版本代码并存
  • 这个问题可以使用jenkins子目录的方式解决
  • jenkins下载不同的版本到自己的子目录,不共享相同目录

新增时,如果没有中文,英文是"checkout to a sub directory"

测试

[root@jenkins ~]# rm -rf /var/lib/jenkins/workspace/myproject/	#删除之前下载的

执行多次构建,构建不同版本

查看下载目录

[root@jenkins ~]# ls /var/lib/jenkins/workspace/myproject/
myproject-1.0 myproject-1.1

部署代码到web服务器

自动化部署流程

  1. 程序员编写代码,推送到gitlab服务器
  2. Jenkins服务器从gitlab上下载代码
  3. Jenkins处理下载的代码
      • 删除下载目录的版本库(.git本地仓库)
      • 将下载的代码打包
      • 计算程序压缩包的md5值
      • 在Jenkins上安装httpd服务,共享程序压缩包
  4. web服务器下载软件包,并应用(通过脚本实现)
  5. 访问测试

配置共享服务器

  • 在jenkins上安装、配置httpd共享服务器
[root@jenkins ~]# dnf -y install httpd 						#安装apache的软件包
[root@jenkins ~]# mkdir -p /var/www/html/deploy/packages 	#创建jenkins从gitlab上下载的打包代码存放的目录
[root@jenkins ~]# chown -R jenkins:jenkins /var/www/html/deploy/ #修改权限,因为是jenkins自动下载的,需要修改存放的权限
[root@jenkins ~]# systemctl start httpd
[root@jenkins ~]# systemctl enable httpd

配置jenkins把gitlab下载的代码打包

  • 在jenkins上修改myproject项目

pkg_dir=/var/www/html/deploy/packages
cp -r myproject-$web $pkg_dir
rm -rf $pkg_dir/myproject-$web/.git
cd $pkg_dir
tar -zcf myproject-$web.tar.gz myproject-$web
rm -rf myproject-$web
md5sum myproject-$web.tar.gz | awk '{print $1}' > myproject-$web.tar.gz.md5
cd ..
echo -n $web > ver.txt

测试修改的任务

浏览器访问:http://jenkins公网IP/deploy/packages/即可看到打包的代码

web服务自动部署

[root@web1 ~]# dnf -y install httpd  wget 
[root@web1 ~]# mkdir /var/www/download 			#存储jenkins主机上下载的应用代码
[root@web1 ~]# mkdir /var/www/deploy 			#部署应用代码
[root@web1 ~]# systemctl start httpd			#启动httpd服务
[root@web1 ~]# systemctl enable httpd			#将httpd服务设置为开机自启
[root@web1 ~]# ss -ntulp | grep :80				#查看80端口是否正常

编写自动上线脚本

  • 下载软件包
  • 检查软件包是否损坏
  • 解压、部署到web服务器
[root@web1 ~]  # vim web.py
import os
import requests
import hashlib
import tarfile


def has_new_ver(web1_ver_path, ver_url):
    # web1_ver_path 为应用服务器web1主机的当前版本文件路径
    # 如果文件不存在,返回True, 提示没有新版本
    if not os.path.exists(web1_ver_path):
        return True
    # 当web1_ver_path存在时,先获取当前应用的版本号
    with open(web1_ver_path, mode="r") as fr:
        local_ver = fr.read()
    # 通过requests获取jenkins服务器上的最新版本号
    r = requests.get(ver_url)
    # 当web1上的版本号和Jenkins服务器上的版本号不相等时,返回True, 即有新的版本
    if local_ver != r.text:
        return True
    return False


# 声明函数file_ok(), 功能:如果下载的包文件未损坏,则返回True,否则返回False
def file_ok(web1_tar_path, jenkins_tar_md5_url):
    m = hashlib.md5()
    with open(web1_tar_path, mode="rb") as fw:
        while True:
            data = fw.read(4096)
            if len(data) == 0:
                break
            m.update(data)
    # jenkins_tar_md5_url 为jenkins服务器上的压缩包的md5值文件链接地址
    r = requests.get(jenkins_tar_md5_url)
    if m.hexdigest() == r.text.strip():
        # 相等,代表文件未损坏,返回True
        return True
    return False


# 声明函数deploy(), 功能:用于部署软件到 web1 服务器
def deploy(web1_tar_path, web1_deploy_dir, dest):
    tar = tarfile.open(web1_tar_path)  # 打开压缩包web1_tar_path
    tar.extractall(path=web1_deploy_dir)  # 解压到web1_deploy_dir目录下
    tar.close()  # 关闭tar
    # 获取web1_tar_path变量中,最后一个'/',右边的内容,然后做切片,去除".tar.gz",只留下文件名
    file_name = os.path.basename(web1_tar_path)[:-7]
    # 将变量web1_deploy_dir和变量file_name拼接在一起
    app_dir = os.path.join(web1_deploy_dir, file_name)
    # 创建链接,如果软链接dest存在,删除软连接,然后为app_dir创建新的软链接
    if os.path.exists(dest):
        os.remove(dest)
    os.symlink(app_dir, dest)


if __name__ == "__main__":
    ### 判断jenkins服务器上是否有新版本
    # ver_url 为jenkins服务器的当前版本文件路径
    # web1_ver_path 为应用服务器web1主机的当前版本文件路径
    # 这里的地址需要求改为自己的IP地址
    ver_url = "http://120.46.84.196/deploy/ver.txt"
    web1_ver_path = "/var/www/deploy/ver.txt"
    if not has_new_ver(web1_ver_path, ver_url):
        print("no new version~")
        exit(1)
    # ==========================================
    # 如果服务器上有新版本,则下载新版本
    # r.text 为jenkins服务器的当前版本内容
    # jenkins_tar_url 为jenkins服务器上的压缩包链接地址
    # web1_tar_path 为应用服务器web1主机的压缩包路径
    # 这里的地址需要修改为自己的IP地址
    r = requests.get(ver_url)
    jenkins_tar_url = f"http://120.46.84.196/deploy/packages/myproject-{r.text}.tar.gz"
    web1_tar_path = f"/var/www/download/myproject-{r.text}.tar.gz"
    with open(web1_tar_path, mode="wb") as fw:
        fw.write(requests.get(jenkins_tar_url).content)
    # 校验下载的软件包是否损坏,如果损坏则删除 os.remove()
    # jenkins_tar_md5_url 为jenkins服务器上的压缩包的md5值文件链接地址
    jenkins_tar_md5_url = jenkins_tar_url + ".md5"
    if not file_ok(web1_tar_path, jenkins_tar_md5_url):
        print("File has been broken~")
        os.remove(web1_tar_path)
        exit(2)
    # =========================================
    web1_deploy_dir = '/var/www/deploy'
    dest = '/var/www/html/current'
    deploy(web1_tar_path, web1_deploy_dir, dest)
    # 更新本地的版本文件
    if os.path.exists(web1_ver_path):
        os.remove(web1_ver_path)
    with open(web1_ver_path, mode="w") as fw:
        fw.write(requests.get(ver_url).text)
[root@web1 ~]# python3 web.py
[root@web1 html]# ls /var/www/deploy
myproject-1.1  ver.txt

浏览器访问http://web服务器公网IP/current 可以看到部署的文件页面

本文地址:https://www.vps345.com/1846.html

搜索文章

Tags

PV计算 带宽计算 流量带宽 服务器带宽 上行带宽 上行速率 什么是上行带宽? CC攻击 攻击怎么办 流量攻击 DDOS攻击 服务器被攻击怎么办 源IP 服务器 linux 运维 游戏 云计算 javascript 前端 chrome edge ssh deepseek Ollama 模型联网 API CherryStudio python MCP 进程 操作系统 进程控制 Ubuntu llama 算法 opencv 自然语言处理 神经网络 语言模型 ubuntu 数据库 centos oracle 关系型 安全 分布式 macos adb rust http java 网络 开发语言 numpy nginx 监控 自动化运维 阿里云 网络安全 网络协议 harmonyos 华为 typescript 计算机网络 django fastapi flask web3.py flutter 笔记 C 环境变量 进程地址空间 react.js 前端面试题 node.js 持续部署 Dell R750XS 科技 ai 人工智能 个人开发 websocket .net 统信 国产操作系统 虚拟机安装 gitlab c++ 多线程服务器 Linux网络编程 pycharm 深度学习 conda pillow spring json html5 firefox android kubernetes 容器 学习方法 经验分享 程序人生 windows 搜索引擎 c语言 github 创意 社区 docker DeepSeek-R1 API接口 Flask FastAPI Waitress Gunicorn uWSGI Uvicorn Hyper-V WinRM TrustedHosts RTSP xop RTP RTSPServer 推流 视频 kvm 无桌面 命令行 YOLOv8 NPU Atlas800 A300I pro asi_bench matlab mount挂载磁盘 wrong fs type LVM挂载磁盘 Centos7.9 ecm bpm tcp/ip Deepseek unity c# ansible playbook 自动化 蓝耘科技 元生代平台工作流 ComfyUI udp golang 后端 IIS .net core Hosting Bundle .NET Framework vs2022 php html 机器学习 chatgpt 大模型 llama3 Chatglm 开源大模型 深度优先 图论 并集查找 换根法 树上倍增 ollama llm 串口服务器 zotero WebDAV 同步失败 代理模式 YOLO pytorch vue.js audio vue音乐播放器 vue播放音频文件 Audio音频播放器自定义样式 播放暂停进度条音量调节快进快退 自定义audio覆盖默认样式 sql KingBase 银河麒麟 kylin v10 麒麟 v10 mcp mcp-proxy mcp-inspector fastapi-mcp agent sse spring boot tomcat ESP32 LDAP ide nuxt3 vue3 实时音视频 filezilla 无法连接服务器 连接被服务器拒绝 vsftpd 331/530 面试 性能优化 jdk intellij-idea 架构 Docker Compose docker compose docker-compose kylin spring cloud kafka hibernate 运维开发 kamailio sip VoIP TRAE vim 编辑器 根服务器 重启 排查 系统重启 日志 原因 计算机视觉 kind maven 游戏程序 医疗APP开发 app开发 uni-app AI编程 AIGC ffmpeg 音视频 AI大模型 大模型入门 大模型教程 webrtc vscode remote-ssh sqlserver bash Linux ukui 麒麟kylinos openeuler 微服务 远程工作 mysql openEuler android studio ruoyi springboot Nuxt.js jenkins 云原生 ci/cd git 嵌入式硬件 单片机 温湿度数据上传到服务器 Arduino HTTP 需求分析 规格说明书 big data express okhttp CORS 跨域 雨云 NPS apache 孤岛惊魂4 恒源云 java-ee tcp 博客 qt microsoft https Linux PID oneapi 大模型微调 open webui 学习 MQTT 消息队列 fpga开发 远程登录 telnet 报错 pdf asp.net大文件上传 asp.net大文件上传下载 asp.net大文件上传源码 ASP.NET断点续传 asp.net上传文件夹 asp.net上传大文件 .net core断点续传 华为认证 网络工程师 交换机 开源 爬虫 Headless Linux mongodb debian JAVA Java live555 rtsp rtp shell visualstudio k8s zookeeper 驱动开发 硬件工程 嵌入式实习 电脑 Samba SWAT 配置文件 服务管理 网络共享 WSL win11 无法解析服务器的名称或地址 大数据 v10 镜像源 软件 armbian u-boot elasticsearch Cline 企业微信 Linux24.04 deepin ecmascript nextjs react reactjs 流式接口 URL AI Agent ftp stm32 EasyConnect eureka web安全 LLM Web APP Streamlit hadoop opensearch helm ssrf 失效的访问控制 HTML audio 控件组件 vue3 audio音乐播放器 Audio标签自定义样式默认 vue3播放音频文件音效音乐 自定义audio播放器样式 播放暂停调整声音大小下载文件 MI300x DeepSeek openwrt ux 多线程 Python 网络编程 聊天服务器 套接字 TCP 客户端 Socket 小程序 redis svn 向日葵 xrdp 远程桌面 远程连接 string模拟实现 深拷贝 浅拷贝 经典的string类问题 三个swap 游戏服务器 TrinityCore 魔兽世界 开发环境 SSL证书 sysctl.conf vm.nr_hugepages excel chfs ubuntu 16.04 odoo 服务器动作 Server action 能力提升 面试宝典 技术 IT信息化 源码剖析 rtsp实现步骤 流媒体开发 腾讯云 rsyslog 智能路由器 prometheus 银河麒麟操作系统 国产化 rpc 远程过程调用 Windows环境 机器人 直播推流 中间件 C语言 ipython 物联网 FTP服务器 媒体 微信公众平台 3d 数学建模 网络结构图 服务器繁忙 联想开天P90Z装win10 DigitalOcean GPU服务器购买 GPU服务器哪里有 GPU服务器 jmeter 软件测试 av1 电视盒子 机顶盒ROM 魔百盒刷机 gitee ollama下载加速 统信UOS 麒麟 bonding 链路聚合 压力测试 tailscale derp derper 中转 C++软件实战问题排查经验分享 0xfeeefeee 0xcdcdcdcd 动态库加载失败 程序启动失败 程序运行权限 标准用户权限与管理员权限 权限 课程设计 cursor MCP server C/S LLM windows日志 安全架构 Minecraft LORA 大语言模型 NLP H3C iDRAC R720xd 命名管道 客户端与服务端通信 其他 agi Cursor gpu算力 负载均衡 unix Dify es jvm 目标检测 华为云 springsecurity6 oauth2 授权服务器 前后端分离 go 硬件架构 系统架构 服务器无法访问 ip地址无法访问 无法访问宝塔面板 宝塔面板打不开 pygame 小游戏 五子棋 FunASR ASR 佛山戴尔服务器维修 佛山三水服务器维修 交互 file server http server web server ssl 集成学习 集成测试 jar arm minio Docker Hub docker pull daemon.json 代码调试 ipdb rdp 实验 僵尸进程 UOS 统信操作系统 yum oceanbase rc.local 开机自启 systemd 1024程序员节 MNN Qwen 备份SQL Server数据库 数据库备份 傲梅企业备份网络版 ddos DeepSeek行业应用 Heroku 网站部署 xss 缓存 宝塔面板访问不了 宝塔面板网站访问不了 宝塔面板怎么配置网站能访问 宝塔面板配置ip访问 宝塔面板配置域名访问教程 宝塔面板配置教程 数据集 ios pppoe radius hugo arm开发 flash-attention gaussdb next.js 部署 部署next.js ocr AI agent 思科模拟器 思科 Cisco googlecloud X11 Xming IDEA Reactor 设计模式 C++ EMQX 通信协议 弹性计算 虚拟化 KVM 计算虚拟化 弹性裸金属 idm 漏洞 宝塔面板 同步 备份 建站 安全威胁分析 vscode 1.86 GaN HEMT 氮化镓 单粒子烧毁 辐射损伤 辐照效应 unity3d 安装教程 GPU环境配置 Ubuntu22 CUDA PyTorch Anaconda安装 SSH Xterminal 豆瓣 追剧助手 迅雷 nas 微信 内存 postman mock mock server 模拟服务器 mock服务器 Postman内置变量 Postman随机数据 virtualenv aws 备选 网站 api 调用 示例 银河麒麟桌面操作系统 Kylin OS AutoDL IIS服务器 IIS性能 日志监控 intellij idea 监控k8s集群 集群内prometheus 华为od sqlite dubbo TCP服务器 qt项目 qt项目实战 qt教程 openssl 密码学 模拟退火算法 国标28181 视频监控 监控接入 语音广播 流程 SIP SDP mosquitto 外网访问 内网穿透 端口映射 r语言 数据挖掘 数据可视化 数据分析 word图片自动上传 word一键转存 复制word图片 复制word图文 复制word公式 粘贴word图文 粘贴word公式 transformer 华为机试 nac 802.1 portal 政务 分布式系统 监控运维 Prometheus Grafana proxy模式 AISphereButler CH340 串口驱动 CH341 uart 485 HAProxy 5G 3GPP 卫星通信 大数据平台 虚拟局域网 银河麒麟高级服务器 外接硬盘 Kylin echarts 信息可视化 网页设计 gradle c 框架搭建 系统安全 显卡驱动 回显服务器 UDP的API使用 vSphere vCenter llama.cpp VMware安装mocOS VMware macOS系统安装 Java Applet URL操作 服务器建立 Socket编程 网络文件读取 mac bcompare Beyond Compare 模拟器 教程 ESXi Dell HPE 联想 浪潮 tcpdump ros rust腐蚀 devops 微信小程序 dify ceph Python基础 Python教程 Python技巧 网络用户购物行为分析可视化平台 大数据毕业设计 web GCC Linux环境 升级 CVE-2024-7347 RAGFlow 云服务器 VPS 无人机 .net mvc断点续传 gateway 实战案例 序列化反序列化 gcc 数据结构 zabbix iBMC UltraISO Claude 测试工具 autodl 软件定义数据中心 sddc 深度求索 私域 知识库 RTMP 应用层 jupyter 反向代理 mcu iot 信息与通信 AnythingLLM AnythingLLM安装 虚幻 游戏引擎 线程 状态模式 智能手机 矩阵 飞书 wsl web3 程序员 EMUI 回退 降级 环境配置 中兴光猫 换光猫 网络桥接 自己换光猫 传统数据库升级 银行 LLMs springboot远程调试 java项目远程debug docker远程debug java项目远程调试 springboot远程 职场和发展 单一职责原则 IPMITOOL BMC 硬件管理 ArkUI 多端开发 智慧分发 应用生态 鸿蒙OS opcua opcda KEPServer安装 P2P HDLC 工业4.0 k8s资源监控 annotations自动化 自动化监控 监控service 监控jvm frp IMM QT 5.12.12 QT开发环境 Ubuntu18.04 双系统 GRUB引导 Linux技巧 apt 腾讯云大模型知识引擎 rtsp服务器 rtsp server android rtsp服务 安卓rtsp服务器 移动端rtsp服务 大牛直播SDK docker搭建nacos详解 docker部署nacos docker安装nacos 腾讯云搭建nacos centos7搭建nacos 微信开放平台 微信公众号配置 gitea springcloud 鸿蒙 鸿蒙系统 前端框架 游戏开发 hexo 移动云 可信计算技术 鲲鹏 小智AI服务端 xiaozhi TTS FTP 服务器 RAID RAID技术 磁盘 存储 图像处理 can 线程池 单元测试 功能测试 selenium uniapp 技能大赛 计算机外设 ui SSL 域名 Anolis nginx安装 环境安装 linux插件下载 昇腾 npu 元服务 应用上架 mariadb ssh远程登录 自定义客户端 SAS 图形化界面 换源 国内源 Debian 僵尸世界大战 游戏服务器搭建 多进程 远程 命令 执行 sshpass 操作 linux上传下载 健康医疗 互联网医院 nfs wps 安卓 crosstool-ng rabbitmq rnn 大大通 第三代半导体 碳化硅 vmware 卡死 HarmonyOS Next ldap 毕昇JDK wsl2 webstorm Trae IDE AI 原生集成开发环境 Trae AI tensorflow 浏览器开发 AI浏览器 npm linux安装配置 嵌入式 linux驱动开发 Kali Linux 黑客 渗透测试 信息收集 h.264 micropython esp32 mqtt selete 高级IO HarmonyOS 多层架构 解耦 seatunnel RustDesk自建服务器 rustdesk服务器 docker rustdesk yaml Ultralytics 可视化 黑客技术 项目部署到linux服务器 项目部署过程 本地部署 pyqt deekseek ragflow 微信小程序域名配置 微信小程序服务器域名 微信小程序合法域名 小程序配置业务域名 微信小程序需要域名吗 微信小程序添加域名 半虚拟化 硬件虚拟化 Hypervisor etl etcd 数据安全 RBAC wireshark vscode1.86 1.86版本 ssh远程连接 田俊楠 SSE rocketmq open Euler dde 迁移指南 网卡的名称修改 eth0 ens33 微信分享 Image wxopensdk .netcore ue4 着色器 ue5 cpp-httplib 网工 postgresql pgpool 开机自启动 rag ragflow 源码启动 grafana 视觉检测 adobe Docker引擎已经停止 Docker无法使用 WSL进度一直是0 镜像加速地址 elk bug clickhouse outlook 信号 jina cuda cudnn anaconda mamba Vmamba rclone AList webdav fnOS dash 正则表达式 ip 小艺 Pura X IMX317 MIPI H265 VCU visual studio code 群晖 文件分享 软件工程 iis Linux的基础指令 W5500 OLED u8g2 雨云服务器 token sas 环境迁移 lio-sam SLAM 服务器管理 配置教程 服务器安装 网站管理 崖山数据库 YashanDB composer 视频编解码 pip 宠物 毕业设计 免费学习 宠物领养 宠物平台 Ubuntu 24.04.1 轻量级服务器 NFS redhat 产测工具框架 IMX6ULL 管理框架 matplotlib python3.11 cpu 实时 使用 高效日志打印 串口通信日志 服务器日志 系统状态监控日志 异常记录日志 历史版本 下载 安装 毕设 相差8小时 UTC 时间 rustdesk 远程控制 远程看看 远程协助 HiCar CarLife+ CarPlay QT RK3588 yolov8 Node-Red 编程工具 流编程 知识图谱 网络穿透 CPU safari Mac 系统 VR手套 数据手套 动捕手套 动捕数据手套 dns nvidia 低代码 三级等保 服务器审计日志备份 程序 编程 性能分析 bat OD机试真题 华为OD机试真题 服务器能耗统计 bootstrap 策略模式 单例模式 软考 linux 命令 sed 命令 css 7z 智能音箱 智能家居 输入法 服务器数据恢复 数据恢复 存储数据恢复 北亚数据恢复 oracle数据恢复 多个客户端访问 IO多路复用 TCP相关API 实时互动 prompt easyui langchain list 模拟实现 主板 电源 网卡 网络攻击模型 线性代数 电商平台 大文件分片上传断点续传及进度条 如何批量上传超大文件并显示进度 axios大文件切片上传详细教 node服务器合并切片 vue3大文件上传报错提示错误 大文件秒传跨域报错cors DevEco Studio XCC Lenovo 自动驾驶 压测 ECS 繁忙 解决办法 替代网站 汇总推荐 AI推理 n8n 工作流 workflow fd 文件描述符 CDN Clion Nova ResharperC++引擎 Centos7 远程开发 keepalived dba embedding IPv4 子网掩码 公网IP 私有IP Windows SSH 密钥生成 SSH 公钥 私钥 生成 Qwen2.5-coder 离线部署 Linux find grep wsgiref Web 服务器网关接口 flink cocoapods xcode 代理 threejs 3D skynet SenseVoice DOIT 四博智联 yum源切换 更换国内yum源 防火墙 NAT转发 NAT Server Unity Dedicated Server Host Client 无头主机 stm32项目 SSH 服务 SSH Server OpenSSH Server ardunio BLE 端口测试 合成模型 扩散模型 图像生成 iperf3 带宽测试 常用命令 文本命令 目录命令 ShenTong 计算机 thingsboard 磁盘监控 dell服务器 iventoy VmWare OpenEuler css3 OpenHarmony 真机调试 XFS xfs文件系统损坏 I_O error 服务器主板 AI芯片 Jellyfin sdkman sequoiaDB 服务器配置 生物信息学 Wi-Fi 超融合 prometheus数据采集 prometheus数据模型 prometheus特点 Spring Security 我的世界 我的世界联机 数码 相机 我的世界服务器搭建 asm AI-native Docker Desktop 王者荣耀 IPMI 带外管理 软链接 硬链接 混合开发 JDK db 硬件 设备 GPU PCI-Express WebUI DeepSeek V3 办公自动化 自动化生成 pdf教程 jetty undertow tidb GLIBC 虚拟机 ISO镜像作为本地源 mysql离线安装 ubuntu22.04 mysql8.0 云服务 文件系统 路径解析 云电竞 云电脑 todesk 源码 webgl Erlang OTP gen_server 热代码交换 事务语义 Ubuntu DeepSeek DeepSeek Ubuntu DeepSeek 本地部署 DeepSeek 知识库 DeepSeek 私有化知识库 本地部署 DeepSeek DeepSeek 私有化部署 流水线 脚本式流水线 efficientVIT YOLOv8替换主干网络 TOLOv8 centos-root /dev/mapper yum clean all df -h / du -sh 考研 onlyoffice 在线office sqlite3 g++ g++13 cnn DenseNet 基础入门 CrewAI ruby log4j hive Hive环境搭建 hive3环境 Hive远程模式 freebsd Xinference glibc pyautogui Linux awk awk函数 awk结构 awk内置变量 awk参数 awk脚本 awk详解 dns是什么 如何设置电脑dns dns应该如何设置 chrome 浏览器下载 chrome 下载安装 谷歌浏览器下载 架构与原理 VMware安装Ubuntu Ubuntu安装k8s 测试用例 AI写作 AI作画 QQ 聊天室 epoll 信号处理 WSL2 IM即时通讯 剪切板对通 HTML FORMAT MySql RAGFLOW 移动魔百盒 cd 目录切换 Radius USB转串口 飞牛NAS 飞牛OS MacBook Pro camera Arduino 电子信息 harmonyOS面试题 GoogLeNet muduo Typore 个人博客 邮件APP 免费软件 KylinV10 麒麟操作系统 Vmware Ubuntu Server Ubuntu 22.04.5 银河麒麟服务器操作系统 系统激活 k8s集群资源管理 云原生开发 算力 ros2 moveit 机器人运动 高效远程协作 TrustViewer体验 跨设备操作便利 智能远程控制 Ubuntu 24 常用命令 Ubuntu 24 Ubuntu vi 异常处理 aarch64 编译安装 HPC 数据库架构 数据管理 数据治理 数据编织 数据虚拟化 烟花代码 烟花 元旦 lsb_release /etc/issue /proc/version uname -r 查看ubuntu版本 windwos防火墙 defender防火墙 win防火墙白名单 防火墙白名单效果 防火墙只允许指定应用上网 防火墙允许指定上网其它禁止 显示管理器 lightdm gdm 树莓派 VNC Open WebUI 阻塞队列 生产者消费者模型 服务器崩坏原因 laravel Linux无人智慧超市 LInux多线程服务器 QT项目 LInux项目 单片机项目 vue less 直流充电桩 充电桩 域名服务 DHCP 符号链接 配置 deepseek r1 junit xpath定位元素 自动化测试 性能测试 交叉编译 SEO dity make netty 裸金属服务器 弹性裸金属服务器 p2p make命令 makefile文件 sentinel 边缘计算 强化学习 iphone NAS Termux RoboVLM 通用机器人策略 VLA设计哲学 vlm fot robot 视觉语言动作模型 具身智能 iftop 网络流量监控 firewall AD域 致远OA OA服务器 服务器磁盘扩容 镜像 游戏机 抗锯齿 Netty 即时通信 NIO 实习 HTTP 服务器控制 ESP32 DeepSeek uv Kali 状态管理的 UDP 服务器 Arduino RTOS vasp安装 智能硬件 查询数据库服务IP地址 SQL Server 加解密 Yakit yaklang 语音识别 navicat HCIE 数通 gpt 技术共享 ROS wordpress 无法访问wordpess后台 打开网站页面错乱 linux宝塔面板 wordpress更换服务器 Ark-TS语言 MS Materials 金仓数据库 2025 征文 数据库平替用金仓 eclipse 业界资讯 MacOS录屏软件 code-server SVN Server tortoise svn SysBench 基准测试 流量运营 数据库系统 dock 加速 C# MQTTS 双向认证 emqx docker命令大全 cmos ai小智 语音助手 ai小智配网 ai小智教程 esp32语音助手 diy语音助手 RAG 检索增强生成 文档解析 大模型垂直应用 做raid 装系统 gpt-3 文心一言 Ubuntu共享文件夹 共享目录 Linux共享文件夹 人工智能生成内容 金融 火绒安全 内网服务器 内网代理 内网通信 EtherCAT转Modbus ECT转Modbus协议 EtherCAT转485网关 ECT转Modbus串口网关 EtherCAT转485协议 ECT转Modbus网关 VM搭建win2012 win2012应急响应靶机搭建 攻击者获取服务器权限 上传wakaung病毒 应急响应并溯源 挖矿病毒处置 应急响应综合性靶场 eNSP 网络规划 VLAN 企业网络 大模型面经 大模型学习 uni-file-picker 拍摄从相册选择 uni.uploadFile H5上传图片 微信小程序上传图片 neo4j kali 共享文件夹 嵌入式Linux IPC 拓扑图 剧本 gnu docker搭建pg docker搭建pgsql pg授权 postgresql使用 postgresql搭建 IO VS Code 匿名管道 基础环境 开发 ubuntu20.04 开机黑屏 LInux wpf 灵办AI VSCode 链表 沙盒 word AD 域管理 spark HistoryServer Spark YARN jobhistory 多路转接 网站搭建 serv00 项目部署 grub 版本升级 扩容 CentOS Stream CentOS edge浏览器 USB网络共享 Playwright 磁盘镜像 服务器镜像 服务器实时复制 实时文件备份 raid5数据恢复 磁盘阵列数据恢复 软件需求 AP配网 AK配网 小程序AP配网和AK配网教程 WIFI设备配网小程序UDP开 ai工具 java-rocketmq OpenSSH 蓝桥杯 YOLOv12 minecraft trae GIS 遥感 WebGIS ssh漏洞 ssh9.9p2 CVE-2025-23419 内网环境 IO模型 Cookie 分布式训练 Kylin-Server AI代码编辑器 seleium chromedriver 目标跟踪 OpenVINO 推理应用 WebRTC Redis Desktop win服务器架设 windows server 分析解读 ABAP perf 风扇控制软件 DBeaver 数据仓库 kerberos SRS 流媒体 直播 存储维护 NetApp存储 EMC存储 系统开发 binder 车载系统 framework 源码环境 openstack Xen TCP协议 MacMini 迷你主机 mini Apple 服务器部署ai模型 Logstash 日志采集 软负载 CLion milvus AI Agent 字节智能运维 swoole curl wget 端口 查看 ss 程序员创富 risc-v firewalld docker部署翻译组件 docker部署deepl docker搭建deepl java对接deepl 翻译组件使用 西门子PLC 通讯 ubuntu24.04.1 热榜 ip命令 新增网卡 新增IP 启动网卡 visual studio sonoma 自动更新 xshell termius iterm2 rpa 数据库开发 database triton 模型分析 PX4 fast 大模型应用 上传视频至服务器代码 vue3批量上传多个视频并预览 如何实现将本地视频上传到网页 element plu视频上传 ant design vue vue3本地上传视频及预览移除 自动化任务管理 宕机切换 服务器宕机 ArcTS 登录 ArcUI GridItem arkUI 服务网格 istio js 飞牛nas fnos chrome devtools 离线部署dify 企业网络规划 华为eNSP PVE vr 鸿蒙开发 移动开发 mq Unity插件 语法 x64 SIGSEGV xmm0 黑苹果 TrueLicense Linux的权限 捆绑 链接 谷歌浏览器 youtube google gmail 图形渲染 李心怡 trea idea Google pay Apple pay DNS UDP docker部署Python Invalid Host allowedHosts alias unalias 别名 regedit 开机启动 VMware创建虚拟机 键盘 服务器时间 arcgis 影刀 #影刀RPA# 本地化部署 网络爬虫 大模型推理 搭建个人相关服务器 minicom 串口调试工具 音乐服务器 Navidrome 音流 京东云 ping++ 嵌入式系统开发 产品经理 MDK 嵌入式开发工具 论文笔记 sublime text 代理服务器 私有化 在线预览 xlsx xls文件 在浏览器直接打开解析xls表格 前端实现vue3打开excel 文件地址url或接口文档流二进 运维监控 玩机技巧 软件分享 软件图标 增强现实 沉浸式体验 应用场景 技术实现 案例分析 AR bot Docker 虚幻引擎 leetcode 推荐算法 DocFlow figma ubuntu24 vivado24 远程服务 conda配置 conda镜像源 阿里云ECS 论文阅读 自动化编程 怎么卸载MySQL MySQL怎么卸载干净 MySQL卸载重新安装教程 MySQL5.7卸载 Linux卸载MySQL8.0 如何卸载MySQL教程 MySQL卸载与安装 大模型部署 社交电子 Deepseek-R1 私有化部署 推理模型 欧标 OCPP 物联网开发 lua vue-i18n 国际化多语言 vue2中英文切换详细教程 如何动态加载i18n语言包 把语言json放到服务器调用 前端调用api获取语言配置文件 docker run 数据卷挂载 交互模式 音乐库 飞牛 实用教程 本地知识库部署 DeepSeek R1 模型 粘包问题 deep learning searxng midjourney 网络药理学 生信 PPI String Cytoscape CytoHubba rime linux环境变量 信创 信创终端 中科方德 mm-wiki搭建 linux搭建mm-wiki mm-wiki搭建与使用 mm-wiki使用 mm-wiki详解 nlp 干货分享 黑客工具 密码爆破 Windsurf 聚类 mybatis Attention hosts EtherNet/IP串口网关 EIP转RS485 EIP转Modbus EtherNet/IP网关协议 EIP转RS485网关 EIP串口服务器 执法记录仪 智能安全帽 smarteye xml