Docker 容器化的 SonarQube 服务在不同主机之间的迁移


安装 docker-ce

// https://docs.docker.com/install/linux/docker-ce/centos/
$ sudo yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine


$ sudo yum install -y yum-utils \
  device-mapper-persistent-data \
  lvm2

$ sudo yum-config-manager \
    --add-repo \
    https://download.docker.com/linux/centos/docker-ce.repo

$ sudo yum install docker-ce docker-ce-cli containerd.io

$ sudo systemctl start docker

$ sudo docker run hello-world

$ sudo systemctl enable docker


-

sudo groupadd docker     #添加docker用户组
sudo gpasswd -a $USER docker     #将登陆用户加入到docker用户组中
newgrp docker     #更新用户组
docker ps    #测试docker命令是否可以使用sudo正常使用

安装 docker compose

// https://docs.docker.com/compose/install/
sudo curl -L "https://github.com/docker/compose/releases/download/1.24.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

sudo chmod +x /usr/local/bin/docker-compose

sudo ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose

docker-compose --version

把 SonarQube 服务从一台服务器迁移到另一台服务器

// on source host
docker commit db mydb
docker commit sq mysq
docker save mydb -o ./tmp/mydb.tar
docker save mysq -o ./tmp/mysq.tar
scp -r tmp @:/target/path

// on destination host
docker load -i ./tmp/mydb.tar
docker load -i ./tmp/mysq.tar

// 启动镜像却发现没有数据
docker network create sonar
docker run -d --name db --network sonar -e POSTGRES_USER=sonar -e POSTGRES_PASSWORD=sonar mydb
docker run -d --name sq --network sonar -p 9000:9000 -p 9092:9092 -e SONARQUBE_JDBC_USERNAME=sonar -e SONARQUBE_JDBC_PASSWORD=sonar -e SONARQUBE_JDBC_URL=jdbc:postgresql://db:5432/sonar mysq

只能从原数据库导出数据,往新数据库导入数据

// on the source host
docker exec -it db sh
# su - postgres
#  pg_dump -U sonar sonar > /tmp/mysq.sql
# exit
# exit
docker cp :/tmp/mysq.sql ~/tmp/
scp ~/tmp/mysq.sql @:/target/path

// on destination host
docker cp /target/path/mysq.sql  :/tmp/
docker exec -it db sh
# su - postgres
# dropdb -U sonar sonar
# createdb -U sonar sonar
# psql -d sonar -U sonar -f /tmp/mysq.sql  
# exit
# exit

检验

经过以上步骤,我可以 admin 账户之外的原自定义 chenjo 账户登录。证明数据迁移成功。

参考文献

  • PostgreSQL 基本表操作命令(一)
  • postgresql 导处与导入数据