# Git服务

# Flag

代码跟踪分析

Gogs

Gitea

# GitLab

version: '2'
services:
    gitlab:
      image: 'twang2218/gitlab-ce-zh:11.1.4'
      restart: unless-stopped
      hostname: 'git.woetu.com'
      environment:
        TZ: 'Asia/Shanghai'
        GITLAB_OMNIBUS_CONFIG: |
          external_url 'http://git.woetu.com'
          gitlab_rails['time_zone'] = 'Asia/Shanghai'
          # 需要配置到 gitlab.rb 中的配置可以在这里配置,每个配置一行,注意缩进。
          # 比如下面的电子邮件的配置:
          # gitlab_rails['smtp_enable'] = true
          # gitlab_rails['smtp_address'] = "smtp.exmail.qq.com"
          # gitlab_rails['smtp_port'] = 465
          # gitlab_rails['smtp_user_name'] = "xxxx@xx.com"
          # gitlab_rails['smtp_password'] = "password"
          # gitlab_rails['smtp_authentication'] = "login"
          # gitlab_rails['smtp_enable_starttls_auto'] = true
          # gitlab_rails['smtp_tls'] = true
          # gitlab_rails['gitlab_email_from'] = 'xxxx@xx.com'
      ports:
        - '8099:80'
        - '442:443'
        - '22:22'
      volumes:
        # - /home/gitlab/config:/home/gitlab/config
        # - /home/gitlab/data:/home/gitlab/data
        # - /home/gitlab/logs:/home/gitlab/logs
        - config:/etc/gitlab
        - data:/var/opt/gitlab
        - logs:/var/log/gitlab
volumes:
    config:
    data:
    logs:

# GitHub

统计

# 访问速度过慢

刷新DNS缓存

  • macOS
killall -HUP mDNSResponder
dscacheutil -flushcache
  • Windows
ipconfig /flushdns
  • Linux
service nscd restart
  • Ubuntu
sudo /etc/init.d/dns-clean start

克隆代理地址

  • 替换github.com
    • github.com.cnpmjs.org
    • jlytgs.com/github_
    • github.dyf62976.workers.dev
    • github.wuyanzheshui.workers.dev
    • github.hsmw.workers.dev
    • github.reycn.workers.dev
    • github.itzmx.com

# Actions

生成公钥和私钥ssh-keygen -t rsa -b 4096 -C "yourname@example.com" -f 文件名称 -N ""(ACTION_DEPLOY_KEY), 或者生成新的个人访问令牌(PERSONAL_TOKEN)https://github.com/settings/tokens/new (opens new window)

第三方CI

# GitWebHook

  • 手动部署

Vue项目完成后,执行npm run build,然后将生成的dist目录下的文件放到web目录下

  • WebHooks自动化部署,流程如下:

配置GiteaWebHook通知(也可以用码云GithubGitLabgogs,带WebHook功能就行)

当我们push到仓库时,Gitea会主动发送一个通知到我们的服务器,然后服务器接到通知执行我们部署的脚本,开始自动化构建。

# 配置接收通知

必备环境

  • 以下命令视自己的环境而执行
# git
yum install -y git
# node 由于nodejs自带npm所以就不需要手动安装了
yum install -y nodejs
# vue-cli
npm install -g @vue/cli

# 宝塔面板

  • 设置宝塔WebHook插件

  • 宝塔WebHook获取url

  • param参数需要和脚本里对应起来,我这里写的是pull

http://服务器ip:8888/hook?access_key=5C84B7A5UeXYalfNL6WEpi3jdmmxhFlk3jpvEw02BMo84Ak3&param=pull

# netcat命令

  • 实现监听端口->响应请求->执行脚本部署

  • 一直监听 9999 端口,有请求就响应echo的内容,并执行指定脚本

echo -e "HTTP/1.1 200 ok,glass\r\nConnection: close\r\n\r" |  nc -l 0.0.0.0 9999 ; sh /home/update.sh >> /home/logs/webhook.log 2>&1

通过 systemd,可以将这个脚本管理起来,让它永远重启,这样一次部署之后,马上就可以重新监听,等待下一次部署命令。注意要添加 StartLimitInterval ,限制一下执行的频率。

  • 最终的systemd service如下
[Unit]
Description=Autopull through webhook
After=network.target
 
[Service]
User=admin
Type=simple
ExecStart=/bin/bash -xc 'echo -e "HTTP/1.1 200 ok,glass\r\nConnection: close\r\n\r" |  nc -l 0.0.0.0 9999 ; sh /home/deploy/update.sh >> /home/logs/webhook.log 2>&1'
Restart=always
StartLimitInterval=1min
StartLimitBurst=60
 
[Install]
WantedBy=multi-user.target

这样就可以实现每次向 master push 代码,自动测试成功并且马上推送到测试环境中。 update.sh 脚本的最后可以加一个 Curl 命令向钉钉或者 slack 发送提醒。

# 配置WebHook

# 添加接收通知url

# 测试推送