Commit 2964317a749299aca662ef4156aedf4c68d99083
1 parent
2ea16684
feat: docker安装部署
Showing
10 changed files
with
223 additions
and
5 deletions
Show diff stats
.gitignore
Makefile
| @@ -52,5 +52,23 @@ gen:proto excel | @@ -52,5 +52,23 @@ gen:proto excel | ||
| 52 | pull: | 52 | pull: |
| 53 | git submodule update --remote | 53 | git submodule update --remote |
| 54 | 54 | ||
| 55 | +docker-build: | ||
| 56 | + # docker build -t my-tab -f /abc/defg/my-dockerfile /context-dir | ||
| 57 | + docker build -t pro2d -f docker/Dockerfile ./ --force-rm | ||
| 58 | + | ||
| 59 | +docker-http: | ||
| 60 | + docker rm -f http-pro2d | ||
| 61 | + docker run --restart=always -d -p 8080:8080 --name http-pro2d pro2d ./http | ||
| 62 | + | ||
| 63 | +docker-game: | ||
| 64 | + docker rm -f game-pro2d | ||
| 65 | + docker run --restart=always -d -p 8850:8850 --name game-pro2d pro2d ./game | ||
| 66 | + | ||
| 67 | +save: docker-build | ||
| 68 | + docker save pro2d > docker/pro2d.tar | ||
| 69 | + scp docker/* zhaolu@192.168.0.100:/Users/zhaolu/Documents/pro2d #passwd: zhaolu | ||
| 70 | + | ||
| 71 | + rm -f docker/pro2d.tar | ||
| 72 | + ssh zhaolu@192.168.0.100 "/Users/zhaolu/Documents/pro2d/restart.sh" | ||
| 55 | 73 | ||
| 56 | .PHONY: all build protos test cert plugin doc proto pull | 74 | .PHONY: all build protos test cert plugin doc proto pull |
| 57 | \ No newline at end of file | 75 | \ No newline at end of file |
common/conf.go
| @@ -117,7 +117,7 @@ func init() { | @@ -117,7 +117,7 @@ func init() { | ||
| 117 | return | 117 | return |
| 118 | } | 118 | } |
| 119 | //初始化日志 | 119 | //初始化日志 |
| 120 | - err = logger.SetLogger(string(c), strings.ToLower(GlobalConf.GameConf.Name)) | 120 | + err = logger.SetLogger(string(c), fmt.Sprintf("logs/%s", strings.ToLower(GlobalConf.GameConf.Name))) |
| 121 | if err != nil { | 121 | if err != nil { |
| 122 | fmt.Errorf("log conf %v", err) | 122 | fmt.Errorf("log conf %v", err) |
| 123 | return | 123 | return |
conf/conf.yaml
| @@ -4,10 +4,10 @@ workerid: 1 | @@ -4,10 +4,10 @@ workerid: 1 | ||
| 4 | datacenterid: 1 | 4 | datacenterid: 1 |
| 5 | 5 | ||
| 6 | mongo: &default-mongo | 6 | mongo: &default-mongo |
| 7 | - host: "192.168.0.206" | 7 | + host: "192.168.0.100" |
| 8 | port: 27017 | 8 | port: 27017 |
| 9 | - user: "" | ||
| 10 | - password: "" | 9 | + user: "root" |
| 10 | + password: "root" | ||
| 11 | timeout: 2 | 11 | timeout: 2 |
| 12 | maxnum: 50 | 12 | maxnum: 50 |
| 13 | 13 |
| @@ -0,0 +1,33 @@ | @@ -0,0 +1,33 @@ | ||
| 1 | +FROM golang:1.17 as Go117Build | ||
| 2 | +WORKDIR /usr/src/app | ||
| 3 | +#COPY go.mod go.sum ./ | ||
| 4 | +#RUN go mod download && go mod verify | ||
| 5 | + | ||
| 6 | +COPY . . | ||
| 7 | +RUN go build -tags netgo -o /usr/local/bin/http cmd/httpserver/main.go && go build -tags netgo -o /usr/local/bin/game cmd/gameserver/*.go | ||
| 8 | + | ||
| 9 | +FROM alpine:3.7 as pro2d | ||
| 10 | +# 配置国内源 | ||
| 11 | +RUN echo "http://mirrors.aliyun.com/alpine/v3.7/main/" > /etc/apk/repositories && \ | ||
| 12 | + echo "hosts: files dns" > /etc/nsswitch.conf #dns | ||
| 13 | +RUN apk update && \ | ||
| 14 | + apk add ca-certificates && \ | ||
| 15 | + apk add libc6-compat | ||
| 16 | + | ||
| 17 | +WORKDIR /data | ||
| 18 | + | ||
| 19 | +COPY --from=0 /usr/local/bin/http . | ||
| 20 | +COPY --from=0 /usr/local/bin/game . | ||
| 21 | +COPY csvdata/data ./csvdata/data | ||
| 22 | +COPY ./docker/conf.yaml ./conf/ | ||
| 23 | + | ||
| 24 | + | ||
| 25 | +RUN mkdir -p /data/logs && \ | ||
| 26 | + echo 'export PATH=$PATH:/data' >> /etc/profile && \ | ||
| 27 | + source /etc/profile | ||
| 28 | +#RUN apt-get update && \ | ||
| 29 | +# apt-get install -y net-tools iputils-ping iproute2 | ||
| 30 | +EXPOSE 8080 | ||
| 31 | +EXPOSE 8849 | ||
| 32 | + | ||
| 33 | +CMD ["http"] | ||
| 0 | \ No newline at end of file | 34 | \ No newline at end of file |
| @@ -0,0 +1,93 @@ | @@ -0,0 +1,93 @@ | ||
| 1 | +develop: true | ||
| 2 | +name: "Pro2DServer" | ||
| 3 | +workerid: 1 | ||
| 4 | +datacenterid: 1 | ||
| 5 | + | ||
| 6 | +mongo: &default-mongo | ||
| 7 | + host: "host.docker.internal" | ||
| 8 | + port: 27017 | ||
| 9 | + user: "root" | ||
| 10 | + password: "root" | ||
| 11 | + timeout: 2 | ||
| 12 | + maxnum: 50 | ||
| 13 | + | ||
| 14 | +redis: &default-redis | ||
| 15 | + address: "host.docker.internal:6100" | ||
| 16 | + auth: "" | ||
| 17 | + | ||
| 18 | +etcd: | ||
| 19 | + dialtimeout: 5 | ||
| 20 | + endpoints: | ||
| 21 | + - "host.docker.internal:2379" | ||
| 22 | + | ||
| 23 | +server_account: | ||
| 24 | + id: 1 | ||
| 25 | + name: "account" | ||
| 26 | + ip: "192.168.0.206" | ||
| 27 | + port: 8080 | ||
| 28 | + pool_size: 1 | ||
| 29 | + debugport: 6062 | ||
| 30 | + mongo: | ||
| 31 | + <<: *default-mongo | ||
| 32 | + dbname: "account" | ||
| 33 | + redis: | ||
| 34 | + <<: *default-redis | ||
| 35 | + db: 0 | ||
| 36 | + | ||
| 37 | +server_game: | ||
| 38 | + id: 1 | ||
| 39 | + name: "game" | ||
| 40 | + ip: "192.168.0.206" | ||
| 41 | + encipher: false | ||
| 42 | + port: 8849 | ||
| 43 | + debugport: 6060 | ||
| 44 | + gm: 8880 | ||
| 45 | + pool_size: 1 | ||
| 46 | + plugin_path: "./bin/plugin.so" | ||
| 47 | + mongo: | ||
| 48 | + <<: *default-mongo | ||
| 49 | + dbname: "game" | ||
| 50 | + redis: | ||
| 51 | + <<: *default-redis | ||
| 52 | + db: 0 | ||
| 53 | + | ||
| 54 | +server_game1: | ||
| 55 | + id: 2 | ||
| 56 | + name: "game" | ||
| 57 | + ip: "192.168.0.206" | ||
| 58 | + encipher: false | ||
| 59 | + port: 8850 | ||
| 60 | + debugport: 6061 | ||
| 61 | + gm: 8881 | ||
| 62 | + pool_size: 1 | ||
| 63 | + plugin_path: "./bin/plugin.so" | ||
| 64 | + mongo: | ||
| 65 | + <<: *default-mongo | ||
| 66 | + dbname: "game" | ||
| 67 | + redis: | ||
| 68 | + <<: *default-redis | ||
| 69 | + db: 0 | ||
| 70 | +test_client: | ||
| 71 | + ip: "127.0.0.1" | ||
| 72 | + port: 8849 | ||
| 73 | + count: 1 | ||
| 74 | + | ||
| 75 | +logconf: | ||
| 76 | + TimeFormat: "2006-01-02 15:04:05" | ||
| 77 | + Console: | ||
| 78 | + level: "TRAC" | ||
| 79 | + color: true | ||
| 80 | + File: | ||
| 81 | + level: "TRAC" | ||
| 82 | + daily: true | ||
| 83 | + maxlines: 1000000 | ||
| 84 | + maxsize: 1 | ||
| 85 | + maxdays: -1 | ||
| 86 | + append: true | ||
| 87 | + permit: "0660" | ||
| 88 | +# Conn: | ||
| 89 | +# net: "tcp" | ||
| 90 | +# addr: "127.0.0.1" | ||
| 91 | +# level: "TRAC" | ||
| 92 | +# reconnect: false | ||
| 93 | +# reconnectOnMsg: false | ||
| 0 | \ No newline at end of file | 94 | \ No newline at end of file |
| @@ -0,0 +1,51 @@ | @@ -0,0 +1,51 @@ | ||
| 1 | +version: '3.3' | ||
| 2 | +services: | ||
| 3 | + db: | ||
| 4 | + image: mongo | ||
| 5 | + container_name: mongodb-pro2d | ||
| 6 | + ports: | ||
| 7 | + - '27017:27017' | ||
| 8 | + restart: always | ||
| 9 | + environment: | ||
| 10 | + MONGO_INITDB_ROOT_USERNAME: root #mongo默认的账号 | ||
| 11 | + MONGO_INITDB_ROOT_PASSWORD: root #mongo默认的密码 | ||
| 12 | + volumes: | ||
| 13 | + - ./.docker/mongo_data:/data/db | ||
| 14 | + - ./.docker/mongo.conf:/data/mongo.conf | ||
| 15 | +# command: --config /data/mongo.conf # 配置文件 | ||
| 16 | + command: [--auth] # 配置文件 | ||
| 17 | + etcd: | ||
| 18 | + image: xieyanze/etcd3 | ||
| 19 | + container_name: etcd3-pro2d | ||
| 20 | + restart: always | ||
| 21 | + ports: | ||
| 22 | + - '2379:2379' | ||
| 23 | + redis: | ||
| 24 | + image: redis:latest | ||
| 25 | + container_name: redis-pro2d | ||
| 26 | + restart: always | ||
| 27 | + ports: | ||
| 28 | + - '6100:6379' | ||
| 29 | + volumes: | ||
| 30 | + - ./.docker/redis_data:/data/db | ||
| 31 | + | ||
| 32 | + account: | ||
| 33 | + image: pro2d | ||
| 34 | + container_name: account-pro2d | ||
| 35 | + restart: always | ||
| 36 | + ports: | ||
| 37 | + - '8080:8080' | ||
| 38 | + volumes: | ||
| 39 | + - ./.docker/account_logs:/data/logs | ||
| 40 | + working_dir: /data | ||
| 41 | + command: [./http] | ||
| 42 | + game: | ||
| 43 | + image: pro2d | ||
| 44 | + container_name: game-pro2d | ||
| 45 | + restart: always | ||
| 46 | + ports: | ||
| 47 | + - '8849:8849' | ||
| 48 | + volumes: | ||
| 49 | + - ./.docker/game_logs:/data/logs | ||
| 50 | + working_dir: /data | ||
| 51 | + command: [./game] |
| @@ -0,0 +1,7 @@ | @@ -0,0 +1,7 @@ | ||
| 1 | +#!/bin/bash | ||
| 2 | + | ||
| 3 | +host='-H 192.168.0.100:2375' | ||
| 4 | +docker-compose -f /Users/zhaolu/Documents/pro2d/docker-compose.yml down | ||
| 5 | +docker load < /Users/zhaolu/Documents/pro2d/pro2d.tar | ||
| 6 | +docker-compose -f /Users/zhaolu/Documents/pro2d/docker-compose.yml up -d | ||
| 7 | +docker ps -a | ||
| 0 | \ No newline at end of file | 8 | \ No newline at end of file |