微服务的编程测评系统-linux部署指令

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 前言
  • [1. 安装docker](#1. 安装docker)
  • [2. 开启docker远程访问](#2. 开启docker远程访问)
  • [3 mysql](#3 mysql)
    • [3.1 mysql初始化](#3.1 mysql初始化)
  • [4. nacos](#4. nacos)
    • [4.1 nacos配置](#4.1 nacos配置)
  • [5. 其他组件的docker-compose](#5. 其他组件的docker-compose)
  • [6. 后端部署](#6. 后端部署)
    • [6.1 nginx配置修改](#6.1 nginx配置修改)
  • [7. 测试](#7. 测试)
  • 总结

前言

1. 安装docker

java 复制代码
apt update

卸载旧版本

java 复制代码
sudo apt-get remove docker \
               docker-engine \
               docker.io

安装docker(鉴于国内网络问题,此处使用国内源安装)

添加使用 HTTPS 传输的软件包以及 CA 证书

java 复制代码
sudo apt-get update

sudo apt-get install \
    apt-transport-https \
    ca-certificates \
    curl \
    gnupg \
    lsb-release

添加软件源的 GPG 密钥

java 复制代码
curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg

向 sources.list 中添加 Docker 软件源

java 复制代码
echo \  "deb [arch=amd64 signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://mirrors.aliyun.com/docker-ce/linux/ubuntu \
  $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null

安装

java 复制代码
sudo apt-get update
sudo apt-get install docker-ce docker-ce-cli containerd.io

启动docker

java 复制代码
sudo systemctl enable docker
sudo systemctl start docker

一步都不要少

java 复制代码
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": [
      "https://registry.docker-cn.com",
    "http://hub-mirror.c.163.com",
    "https://docker.mirrors.ustc.edu.cn",
    "https://dockerhub.azk8s.cn",
    "https://mirror.ccs.tencentyun.com",
    "https://registry.cn-hangzhou.aliyuncs.com",
    "https://docker.mirrors.ustc.edu.cn",
    "https://docker.1panel.live",
    "https://atomhub.openatom.cn/",
    "https://hub.uuuadc.top",
    "https://docker.anyhub.us.kg",
    "https://dockerhub.jobcher.com",
    "https://dockerhub.icu",
    "https://docker.ckyl.me",
    "https://docker.awsl9527.cn"
  ]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

使用的是阿里云服务器,https://euaqkbsw.mirror.aliyuncs.com这个是阿里云的加速镜像,必须是阿里云服务器才可以用

2. 开启docker远程访问

java 复制代码
ip addr show docker0
java 复制代码
vi /lib/systemd/system/docker.service
找到ExecStart 开头的配置,注释原配置 进⾏备份
插⼊以下内容
[Service]
Type=notify
# the default is not to use systemd for cgroups because the delegate issues still
# exists and systemd currently does not support the cgroup feature set required
# for containers run by docker
ExecStart=/usr/bin/dockerd -H tcp://0.0.0.0:2375 -H fd:// --containerd=/run/containerd/containerd.sock
ExecReload=/bin/kill -s HUP $MAINPID
TimeoutStartSec=0
RestartSec=2
Restart=always

就是加上-H tcp://0.0.0.0:2375这个就可以了

重启服务

java 复制代码
systemctl daemon-reload
service docker restart

3 mysql

java 复制代码
mkdir ckoj
cd ckoj

在创建docker-compose.yml文件

java 复制代码
# 指定 Docker Compose ⽂件的版本
version: '3.8'
#services:定义了服务列表
services:
  oj-mysql-server:
    image: mysql:5.7
    container_name: oj-mysql-server
    environment:
      # 时区上海
      TZ: Asia/Shanghai
      # root 密码
      MYSQL_ROOT_PASSWORD: 123456
    ports:
      - "3306:3306"
    volumes:
      # 数据挂载
      - ./mysql/mysqldata/:/var/lib/mysql/
    # 配置MySQL 服务器的字符集与排序规则
    command:
      --character-set-server=utf8mb4
      --collation-server=utf8mb4_general_ci
    # 通过执行特定的 MySQL 命令来检查服务的健康状态
    healthcheck:
      test: ["CMD", "mysqladmin", "ping", "-u", "root", "-p123456"]
      interval: 10s
      timeout: 5s
      retries: 10
java 复制代码
docker compose up -d

3.1 mysql初始化

先用root用户创建一个用户ojtest

java 复制代码
CREATE USER 'ojtest'@'%' IDENTIFIED BY '123456';
CREATE database if NOT EXISTS `ckoj_dev`;
CREATE database if NOT EXISTS `ckoj_nacos_local`;
CREATE database if NOT EXISTS `xxl_job` default character set utf8mb4 collate utf8mb4_unicode_ci;
GRANT CREATE,DROP,SELECT, INSERT, UPDATE, DELETE,ALTER ON ckoj_dev.* TO 'ojtest'@'%';
GRANT CREATE,DROP,SELECT, INSERT, UPDATE, DELETE,ALTER ON ckoj_nacos_local.* TO 'ojtest'@'%';
GRANT CREATE,DROP,SELECT, INSERT, UPDATE, DELETE,ALTER ON xxl_job.* TO 'ojtest'@'%';

然后是nacos数据库配置

java 复制代码
use ckoj_nacos_local;
/******************************************/
/* 表名称 = config_info */
/******************************************/
CREATE TABLE `config_info` (
 `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
 `data_id` varchar(255) NOT NULL COMMENT 'data_id',
 `group_id` varchar(128) DEFAULT NULL COMMENT 'group_id',
 `content` longtext NOT NULL COMMENT 'content',
 `md5` varchar(32) DEFAULT NULL COMMENT 'md5',
 `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
 `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
 `src_user` text COMMENT 'source user',
 `src_ip` varchar(50) DEFAULT NULL COMMENT 'source ip',
 `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',
 `tenant_id` varchar(128) DEFAULT '' COMMENT '租⼾字段',
 `c_desc` varchar(256) DEFAULT NULL COMMENT 'configuration description',
 `c_use` varchar(64) DEFAULT NULL COMMENT 'configuration usage',
 `effect` varchar(64) DEFAULT NULL COMMENT '配置⽣效的描述',
 `type` varchar(64) DEFAULT NULL COMMENT '配置的类型',
 `c_schema` text COMMENT '配置的模式',
 `encrypted_data_key` text NOT NULL COMMENT '密钥',
 PRIMARY KEY (`id`),
 UNIQUE KEY `uk_configinfo_datagrouptenant` (`data_id`,`group_id`,`tenant_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='config_info';
/******************************************/
/* 表名称 = config_info_aggr */
/******************************************/
CREATE TABLE `config_info_aggr` (
 `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
 `data_id` varchar(255) NOT NULL COMMENT 'data_id',
 `group_id` varchar(128) NOT NULL COMMENT 'group_id',
 `datum_id` varchar(255) NOT NULL COMMENT 'datum_id',
 `content` longtext NOT NULL COMMENT '内容',
 `gmt_modified` datetime NOT NULL COMMENT '修改时间',
 `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',
 `tenant_id` varchar(128) DEFAULT '' COMMENT '租⼾字段',
 PRIMARY KEY (`id`),
 UNIQUE KEY `uk_configinfoaggr_datagrouptenantdatum`
(`data_id`,`group_id`,`tenant_id`,`datum_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='增加租⼾字段';
/******************************************/
/* 表名称 = config_info_beta */
/******************************************/
CREATE TABLE `config_info_beta` (
 `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
 `data_id` varchar(255) NOT NULL COMMENT 'data_id',
 `group_id` varchar(128) NOT NULL COMMENT 'group_id',
    `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',
 `content` longtext NOT NULL COMMENT 'content',
 `beta_ips` varchar(1024) DEFAULT NULL COMMENT 'betaIps',
 `md5` varchar(32) DEFAULT NULL COMMENT 'md5',
 `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
 `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
 `src_user` text COMMENT 'source user',
 `src_ip` varchar(50) DEFAULT NULL COMMENT 'source ip',
 `tenant_id` varchar(128) DEFAULT '' COMMENT '租⼾字段',
 `encrypted_data_key` text NOT NULL COMMENT '密钥',
 PRIMARY KEY (`id`),
 UNIQUE KEY `uk_configinfobeta_datagrouptenant`
(`data_id`,`group_id`,`tenant_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin
COMMENT='config_info_beta';
/******************************************/
/* 表名称 = config_info_tag */
/******************************************/
CREATE TABLE `config_info_tag` (
 `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
 `data_id` varchar(255) NOT NULL COMMENT 'data_id',
 `group_id` varchar(128) NOT NULL COMMENT 'group_id',
 `tenant_id` varchar(128) DEFAULT '' COMMENT 'tenant_id',
 `tag_id` varchar(128) NOT NULL COMMENT 'tag_id',
 `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',
 `content` longtext NOT NULL COMMENT 'content',
 `md5` varchar(32) DEFAULT NULL COMMENT 'md5',
 `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
 `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
 `src_user` text COMMENT 'source user',
 `src_ip` varchar(50) DEFAULT NULL COMMENT 'source ip',
 PRIMARY KEY (`id`),
 UNIQUE KEY `uk_configinfotag_datagrouptenanttag`
(`data_id`,`group_id`,`tenant_id`,`tag_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin
COMMENT='config_info_tag';
/******************************************/
/* 表名称 = config_tags_relation */
/******************************************/
CREATE TABLE `config_tags_relation` (
 `id` bigint(20) NOT NULL COMMENT 'id',
 `tag_name` varchar(128) NOT NULL COMMENT 'tag_name',
 `tag_type` varchar(64) DEFAULT NULL COMMENT 'tag_type',
 `data_id` varchar(255) NOT NULL COMMENT 'data_id',
 `group_id` varchar(128) NOT NULL COMMENT 'group_id',
    `tenant_id` varchar(128) DEFAULT '' COMMENT 'tenant_id',
 `nid` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'nid, ⾃增⻓标识',
 PRIMARY KEY (`nid`),
 UNIQUE KEY `uk_configtagrelation_configidtag` (`id`,`tag_name`,`tag_type`),
 KEY `idx_tenant_id` (`tenant_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin
COMMENT='config_tag_relation';
/******************************************/
/* 表名称 = group_capacity */
/******************************************/
CREATE TABLE `group_capacity` (
 `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',
 `group_id` varchar(128) NOT NULL DEFAULT '' COMMENT 'Group ID,空字符表⽰整个集
群',
 `quota` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '配额,0表⽰使⽤默认值',
 `usage` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '使⽤量',
 `max_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个配置⼤⼩上限,单位
为字节,0表⽰使⽤默认值',
 `max_aggr_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '聚合⼦配置最⼤
个数,,0表⽰使⽤默认值',
 `max_aggr_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个聚合数据的⼦
配置⼤⼩上限,单位为字节,0表⽰使⽤默认值',
 `max_history_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '最⼤变更历史
数量',
 `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
 `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
 PRIMARY KEY (`id`),
 UNIQUE KEY `uk_group_id` (`group_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='集群、各Group容量
信息表';
/******************************************/
/* 表名称 = his_config_info */
/******************************************/
CREATE TABLE `his_config_info` (
 `id` bigint(20) unsigned NOT NULL COMMENT 'id',
 `nid` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT 'nid, ⾃增标识',
 `data_id` varchar(255) NOT NULL COMMENT 'data_id',
 `group_id` varchar(128) NOT NULL COMMENT 'group_id',
 `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',
 `content` longtext NOT NULL COMMENT 'content',
 `md5` varchar(32) DEFAULT NULL COMMENT 'md5',
 `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
 `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
 `src_user` text COMMENT 'source user',
 `src_ip` varchar(50) DEFAULT NULL COMMENT 'source ip',
    `op_type` char(10) DEFAULT NULL COMMENT 'operation type',
 `tenant_id` varchar(128) DEFAULT '' COMMENT '租⼾字段',
 `encrypted_data_key` text NOT NULL COMMENT '密钥',
 PRIMARY KEY (`nid`),
 KEY `idx_gmt_create` (`gmt_create`),
 KEY `idx_gmt_modified` (`gmt_modified`),
 KEY `idx_did` (`data_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='多租⼾改造';
/******************************************/
/* 表名称 = tenant_capacity */
/******************************************/
CREATE TABLE `tenant_capacity` (
 `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',
 `tenant_id` varchar(128) NOT NULL DEFAULT '' COMMENT 'Tenant ID',
 `quota` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '配额,0表⽰使⽤默认值',
 `usage` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '使⽤量',
 `max_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个配置⼤⼩上限,单位
为字节,0表⽰使⽤默认值',
 `max_aggr_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '聚合⼦配置最⼤
个数',
 `max_aggr_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个聚合数据的⼦
配置⼤⼩上限,单位为字节,0表⽰使⽤默认值',
 `max_history_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '最⼤变更历史
数量',
 `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
 `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
 PRIMARY KEY (`id`),
 UNIQUE KEY `uk_tenant_id` (`tenant_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='租⼾容量信息表';
CREATE TABLE `tenant_info` (
 `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
 `kp` varchar(128) NOT NULL COMMENT 'kp',
 `tenant_id` varchar(128) default '' COMMENT 'tenant_id',
 `tenant_name` varchar(128) default '' COMMENT 'tenant_name',
 `tenant_desc` varchar(256) DEFAULT NULL COMMENT 'tenant_desc',
 `create_source` varchar(32) DEFAULT NULL COMMENT 'create_source',
 `gmt_create` bigint(20) NOT NULL COMMENT '创建时间',
 `gmt_modified` bigint(20) NOT NULL COMMENT '修改时间',
 PRIMARY KEY (`id`),
 UNIQUE KEY `uk_tenant_info_kptenantid` (`kp`,`tenant_id`),
 KEY `idx_tenant_id` (`tenant_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='tenant_info';
CREATE TABLE `users` (
 `username` varchar(50) NOT NULL PRIMARY KEY COMMENT 'username',
 `password` varchar(500) NOT NULL COMMENT 'password',
 `enabled` boolean NOT NULL COMMENT 'enabled'
);
CREATE TABLE `roles` (
 `username` varchar(50) NOT NULL COMMENT 'username',
 `role` varchar(50) NOT NULL COMMENT 'role',
 UNIQUE INDEX `idx_user_role` (`username` ASC, `role` ASC) USING BTREE
);
CREATE TABLE `permissions` (
 `role` varchar(50) NOT NULL COMMENT 'role',
 `resource` varchar(128) NOT NULL COMMENT 'resource',
 `action` varchar(8) NOT NULL COMMENT 'action',
 UNIQUE INDEX `uk_role_permission` (`role`,`resource`,`action`) USING BTREE
);
INSERT INTO users (username, password, enabled) VALUES ('nacos',
'$2a$10$EuWPZHzz32dJN7jexM34MOeYirDdFAZm2kuWj7VEOJhhZkDrxfvUu', TRUE);
INSERT INTO roles (username, role) VALUES ('nacos', 'ROLE_ADMIN');

然后是xxl-job

java 复制代码
use `xxl_job`;

SET NAMES utf8mb4;

CREATE TABLE `xxl_job_info`
(
    `id`                        int(11)      NOT NULL AUTO_INCREMENT,
    `job_group`                 int(11)      NOT NULL COMMENT '执行器主键ID',
    `job_desc`                  varchar(255) NOT NULL,
    `add_time`                  datetime              DEFAULT NULL,
    `update_time`               datetime              DEFAULT NULL,
    `author`                    varchar(64)           DEFAULT NULL COMMENT '作者',
    `alarm_email`               varchar(255)          DEFAULT NULL COMMENT '报警邮件',
    `schedule_type`             varchar(50)  NOT NULL DEFAULT 'NONE' COMMENT '调度类型',
    `schedule_conf`             varchar(128)          DEFAULT NULL COMMENT '调度配置,值含义取决于调度类型',
    `misfire_strategy`          varchar(50)  NOT NULL DEFAULT 'DO_NOTHING' COMMENT '调度过期策略',
    `executor_route_strategy`   varchar(50)           DEFAULT NULL COMMENT '执行器路由策略',
    `executor_handler`          varchar(255)          DEFAULT NULL COMMENT '执行器任务handler',
    `executor_param`            varchar(512)          DEFAULT NULL COMMENT '执行器任务参数',
    `executor_block_strategy`   varchar(50)           DEFAULT NULL COMMENT '阻塞处理策略',
    `executor_timeout`          int(11)      NOT NULL DEFAULT '0' COMMENT '任务执行超时时间,单位秒',
    `executor_fail_retry_count` int(11)      NOT NULL DEFAULT '0' COMMENT '失败重试次数',
    `glue_type`                 varchar(50)  NOT NULL COMMENT 'GLUE类型',
    `glue_source`               mediumtext COMMENT 'GLUE源代码',
    `glue_remark`               varchar(128)          DEFAULT NULL COMMENT 'GLUE备注',
    `glue_updatetime`           datetime              DEFAULT NULL COMMENT 'GLUE更新时间',
    `child_jobid`               varchar(255)          DEFAULT NULL COMMENT '子任务ID,多个逗号分隔',
    `trigger_status`            tinyint(4)   NOT NULL DEFAULT '0' COMMENT '调度状态:0-停止,1-运行',
    `trigger_last_time`         bigint(13)   NOT NULL DEFAULT '0' COMMENT '上次调度时间',
    `trigger_next_time`         bigint(13)   NOT NULL DEFAULT '0' COMMENT '下次调度时间',
    PRIMARY KEY (`id`)
) ENGINE = InnoDB
  DEFAULT CHARSET = utf8mb4;

CREATE TABLE `xxl_job_log`
(
    `id`                        bigint(20) NOT NULL AUTO_INCREMENT,
    `job_group`                 int(11)    NOT NULL COMMENT '执行器主键ID',
    `job_id`                    int(11)    NOT NULL COMMENT '任务,主键ID',
    `executor_address`          varchar(255)        DEFAULT NULL COMMENT '执行器地址,本次执行的地址',
    `executor_handler`          varchar(255)        DEFAULT NULL COMMENT '执行器任务handler',
    `executor_param`            varchar(512)        DEFAULT NULL COMMENT '执行器任务参数',
    `executor_sharding_param`   varchar(20)         DEFAULT NULL COMMENT '执行器任务分片参数,格式如 1/2',
    `executor_fail_retry_count` int(11)    NOT NULL DEFAULT '0' COMMENT '失败重试次数',
    `trigger_time`              datetime            DEFAULT NULL COMMENT '调度-时间',
    `trigger_code`              int(11)    NOT NULL COMMENT '调度-结果',
    `trigger_msg`               text COMMENT '调度-日志',
    `handle_time`               datetime            DEFAULT NULL COMMENT '执行-时间',
    `handle_code`               int(11)    NOT NULL COMMENT '执行-状态',
    `handle_msg`                text COMMENT '执行-日志',
    `alarm_status`              tinyint(4) NOT NULL DEFAULT '0' COMMENT '告警状态:0-默认、1-无需告警、2-告警成功、3-告警失败',
    PRIMARY KEY (`id`),
    KEY `I_trigger_time` (`trigger_time`),
    KEY `I_handle_code` (`handle_code`),
    KEY `I_jobid_jobgroup` (`job_id`,`job_group`),
    KEY `I_job_id` (`job_id`)
) ENGINE = InnoDB
  DEFAULT CHARSET = utf8mb4;

CREATE TABLE `xxl_job_log_report`
(
    `id`            int(11) NOT NULL AUTO_INCREMENT,
    `trigger_day`   datetime         DEFAULT NULL COMMENT '调度-时间',
    `running_count` int(11) NOT NULL DEFAULT '0' COMMENT '运行中-日志数量',
    `suc_count`     int(11) NOT NULL DEFAULT '0' COMMENT '执行成功-日志数量',
    `fail_count`    int(11) NOT NULL DEFAULT '0' COMMENT '执行失败-日志数量',
    `update_time`   datetime         DEFAULT NULL,
    PRIMARY KEY (`id`),
    UNIQUE KEY `i_trigger_day` (`trigger_day`) USING BTREE
) ENGINE = InnoDB
  DEFAULT CHARSET = utf8mb4;

CREATE TABLE `xxl_job_logglue`
(
    `id`          int(11)      NOT NULL AUTO_INCREMENT,
    `job_id`      int(11)      NOT NULL COMMENT '任务,主键ID',
    `glue_type`   varchar(50) DEFAULT NULL COMMENT 'GLUE类型',
    `glue_source` mediumtext COMMENT 'GLUE源代码',
    `glue_remark` varchar(128) NOT NULL COMMENT 'GLUE备注',
    `add_time`    datetime    DEFAULT NULL,
    `update_time` datetime    DEFAULT NULL,
    PRIMARY KEY (`id`)
) ENGINE = InnoDB
  DEFAULT CHARSET = utf8mb4;

CREATE TABLE `xxl_job_registry`
(
    `id`             int(11)      NOT NULL AUTO_INCREMENT,
    `registry_group` varchar(50)  NOT NULL,
    `registry_key`   varchar(255) NOT NULL,
    `registry_value` varchar(255) NOT NULL,
    `update_time`    datetime DEFAULT NULL,
    PRIMARY KEY (`id`),
    UNIQUE KEY `i_g_k_v` (`registry_group`, `registry_key`, `registry_value`) USING BTREE
) ENGINE = InnoDB
  DEFAULT CHARSET = utf8mb4;

CREATE TABLE `xxl_job_group`
(
    `id`           int(11)     NOT NULL AUTO_INCREMENT,
    `app_name`     varchar(64) NOT NULL COMMENT '执行器AppName',
    `title`        varchar(12) NOT NULL COMMENT '执行器名称',
    `address_type` tinyint(4)  NOT NULL DEFAULT '0' COMMENT '执行器地址类型:0=自动注册、1=手动录入',
    `address_list` text COMMENT '执行器地址列表,多地址逗号分隔',
    `update_time`  datetime             DEFAULT NULL,
    PRIMARY KEY (`id`)
) ENGINE = InnoDB
  DEFAULT CHARSET = utf8mb4;

CREATE TABLE `xxl_job_user`
(
    `id`         int(11)     NOT NULL AUTO_INCREMENT,
    `username`   varchar(50) NOT NULL COMMENT '账号',
    `password`   varchar(50) NOT NULL COMMENT '密码',
    `role`       tinyint(4)  NOT NULL COMMENT '角色:0-普通用户、1-管理员',
    `permission` varchar(255) DEFAULT NULL COMMENT '权限:执行器ID列表,多个逗号分割',
    PRIMARY KEY (`id`),
    UNIQUE KEY `i_username` (`username`) USING BTREE
) ENGINE = InnoDB
  DEFAULT CHARSET = utf8mb4;

CREATE TABLE `xxl_job_lock`
(
    `lock_name` varchar(50) NOT NULL COMMENT '锁名称',
    PRIMARY KEY (`lock_name`)
) ENGINE = InnoDB
  DEFAULT CHARSET = utf8mb4;


## ------------------------------------------------------------------ init data ------------------------------------------------------

INSERT INTO `xxl_job_group`(`id`, `app_name`, `title`, `address_type`, `address_list`, `update_time`)
    VALUES (1, 'xxl-job-executor-sample', '通用执行器Sample', 0, NULL, now()),
           (2, 'xxl-job-executor-sample-ai', 'AI执行器Sample', 0, NULL, now());

INSERT INTO `xxl_job_info`(`id`, `job_group`, `job_desc`, `add_time`, `update_time`, `author`, `alarm_email`,
                           `schedule_type`, `schedule_conf`, `misfire_strategy`, `executor_route_strategy`,
                           `executor_handler`, `executor_param`, `executor_block_strategy`, `executor_timeout`,
                           `executor_fail_retry_count`, `glue_type`, `glue_source`, `glue_remark`, `glue_updatetime`,
                           `child_jobid`)
VALUES (1, 1, '示例任务01', now(), now(), 'XXL', '', 'CRON', '0 0 0 * * ? *',
        'DO_NOTHING', 'FIRST', 'demoJobHandler', '', 'SERIAL_EXECUTION', 0, 0, 'BEAN', '', 'GLUE代码初始化',
        now(), ''),
       (2, 2, 'Ollama示例任务01', now(), now(), 'XXL', '', 'NONE', '',
        'DO_NOTHING', 'FIRST', 'ollamaJobHandler', '{
    "input": "慢SQL问题分析思路",
    "prompt": "你是一个研发工程师,擅长解决技术类问题。"
}', 'SERIAL_EXECUTION', 0, 0, 'BEAN', '', 'GLUE代码初始化',
        now(), ''),
       (3, 2, 'Dify示例任务', now(), now(), 'XXL', '', 'NONE', '',
        'DO_NOTHING', 'FIRST', 'difyWorkflowJobHandler', '{
    "inputs":{
        "input":"查询班级各学科前三名"
    },
    "user": "xxl-job",
    "baseUrl": "http://localhost/v1",
    "apiKey": "app-OUVgNUOQRIMokfmuJvBJoUTN"
}', 'SERIAL_EXECUTION', 0, 0, 'BEAN', '', 'GLUE代码初始化',
        now(), '')
    ;

INSERT INTO `xxl_job_user`(`id`, `username`, `password`, `role`, `permission`)
VALUES (1, 'admin', 'e10adc3949ba59abbe56e057f20f883e', 1, NULL);

INSERT INTO `xxl_job_lock` (`lock_name`)
VALUES ('schedule_lock');

commit;

最后是本身项目依赖的表

java 复制代码
use ckoj_dev;
create table tb_sys_user (
user_id bigint unsigned not null comment '⽤⼾id(主键)',
user_account varchar(20) not null comment '账号',
nick_name varchar(20) comment '昵称',
password char(60) not null comment '密码',
create_by bigint unsigned not null comment '创建⼈',
create_time datetime not null comment '创建时间',
update_by bigint unsigned comment '更新⼈',
update_time datetime comment '跟新时间',
primary key (`user_id`),
unique key `idx_user_account` (`user_account`)
);

create table tb_question(
question_id bigint unsigned not null comment '题⽬id',
title varchar(50) not null comment '题⽬标题',
difficulty tinyint not null comment '题⽬难度1:简单 2:中等 3:困难',
time_limit int not null comment '时间限制',
space_limit int not null comment '空间限制',
content varchar(1000) not null comment '题⽬内容',
question_case varchar(1000) comment '题⽬⽤例',
default_code varchar(500) not null comment '默认代码块',
main_fuc varchar(500) not null comment 'main函数',
create_by bigint unsigned not null comment '创建⼈',
create_time datetime not null comment '创建时间',
update_by bigint unsigned comment '更新⼈',
update_time datetime comment '更新时间',
primary key(`question_id`)
);

create table tb_exam (
exam_id bigint unsigned not null comment '竞赛id(主键)',
title varchar(50) not null comment '竞赛标题',
start_time datetime not null comment '竞赛开始时间',
end_time datetime not null comment '竞赛结束时间',
status tinyint not null default '0' comment '是否发布 0:未发布 1:已发布',
create_by bigint unsigned not null comment '创建⼈',
create_time datetime not null comment '创建时间',
update_by bigint unsigned comment '更新⼈',
update_time datetime comment '更新时间',
primary key(exam_id)
);

create table tb_exam_question (
exam_question_id bigint unsigned not null comment '竞赛题⽬关系id(主键)',
question_id bigint unsigned not null comment '题⽬id(主键)',
exam_id bigint unsigned not null comment '竞赛id(主键)',
question_order int not null comment '题⽬顺序',
create_by bigint unsigned not null comment '创建⼈',
create_time datetime not null comment '创建时间',
update_by bigint unsigned comment '更新⼈',
update_time datetime comment '更新时间',
primary key(exam_question_id)
);

create table tb_user(
user_id bigint unsigned NOT NULL COMMENT '⽤⼾id(主键)',
nick_name varchar(20) comment '⽤⼾昵称',
head_image varchar(100) comment '⽤⼾头像',
sex tinyint comment '⽤⼾状态1: 男 2:⼥',
phone char(11) not null comment '⼿机号',
code char(6) comment '验证码',
email varchar(20) comment '邮箱',
wechat varchar(20) comment '微信号',
school_name varchar(20) comment '学校',
major_name varchar(20) comment '专业',
introduce varchar(100) comment '个⼈介绍',
status tinyint not null comment '⽤⼾状态0: 拉⿊ 1:正常',
create_by bigint unsigned not null comment '创建⼈',
create_time datetime not null comment '创建时间',
update_by bigint unsigned comment '更新⼈',
update_time datetime comment '更新时间',
primary key(`user_id`)
);

create table tb_user_exam(
user_exam_id bigint unsigned NOT NULL COMMENT '⽤⼾竞赛关系id',
user_id bigint unsigned NOT NULL COMMENT '⽤⼾id',
exam_id bigint unsigned NOT NULL COMMENT '竞赛id',
score int unsigned COMMENT '得分',
exam_rank int unsigned COMMENT '排名',
create_by bigint unsigned not null comment '创建⼈',
create_time datetime not null comment '创建时间',
update_by bigint unsigned comment '更新⼈',
update_time datetime comment '更新时间',
primary key(user_exam_id)
);

create table tb_user_submit(
submit_id bigint unsigned NOT NULL COMMENT '提交记录id',
user_id bigint unsigned NOT NULL COMMENT '⽤⼾id',
question_id bigint unsigned NOT NULL COMMENT '题⽬id',
exam_id bigint unsigned COMMENT '竞赛id',
program_type tinyint NOT NULL COMMENT '代码类型 0 java 1 CPP',
user_code text NOT NULL COMMENT '⽤⼾代码',
pass tinyint NOT NULL COMMENT '0:未通过 1:通过',
exe_message varchar(500) COMMENT '执⾏结果',
case_judge_res varchar(1000) COMMENT '测试⽤例输出结果',
score int NOT NULL DEFAULT '0' COMMENT '得分',
create_by bigint unsigned not null comment '创建⼈',
create_time datetime not null comment '创建时间',
update_by bigint unsigned comment '更新⼈',
update_time datetime comment '更新时间',
primary key(`submit_id`)
);

create table tb_message_text(
text_id bigint unsigned NOT NULL COMMENT '消息内容id(主键)',
message_title varchar(10) NOT NULL COMMENT '消息标题',
message_content varchar(200) NOT NULL COMMENT '消息内容',
create_by bigint unsigned not null comment '创建⼈',
create_time datetime not null comment '创建时间',
update_by bigint unsigned comment '更新⼈',
update_time datetime comment '更新时间',
primary key (text_id)
);

create table tb_message(
message_id bigint unsigned NOT NULL COMMENT '消息id(主键)',
text_id bigint unsigned NOT NULL COMMENT '消息内容id(主键)',
send_id bigint unsigned NOT NULL COMMENT '消息发送⼈id',
rec_id bigint unsigned NOT NULL COMMENT '消息接收⼈id',
create_by bigint unsigned not null comment '创建⼈',
create_time datetime not null comment '创建时间',
update_by bigint unsigned comment '更新⼈',
update_time datetime comment '更新时间',
primary key (message_id)
);

4. nacos

java 复制代码
  oj-nacos-server:
    image: nacos/nacos-server:v2.2.2  # 替换为nacos的Docker镜像名及版本
    container_name: oj-nacos-server
    # 设置 Nacos 的运行模式为独立模式,限制了 Java 虚拟机的内存使用,并指定连接到 oj-mysql-server 数据库的信息
    environment:
      - MODE=standalone
      - JVM_XMS=256m
      - JVM_XMX=256m
      - SPRING_DATASOURCE_PLATFORM=mysql
      - MYSQL_SERVICE_HOST=oj-mysql-server
      - MYSQL_SERVICE_PORT=3306
      - MYSQL_SERVICE_DB_NAME=ckoj_nacos_local
      - MYSQL_SERVICE_USER=ojtest
      - MYSQL_SERVICE_PASSWORD=123456
    volumes:
      - ./nacos/conf/application.properties:/home/nacos/conf/application.properties
    # 将容器的 8848 和 9848 端口映射到主机的对应端口
    ports:
      - "8848:8848"
      - "9848:9848"
    depends_on:
      oj-mysql-server:
        condition: service_healthy
    healthcheck:
      test: [ "CMD", "curl", "-f", "http://localhost:8848/nacos" ]
      interval: 30s
      timeout: 10s
      retries: 10


为什么要上传呢,因为我们修改了这个配置文件,如果没有修改的话,挂载的就是默认配置文件,不用上传

java 复制代码
docker compose up -d

开放端口8848,9848,3306,

nacos需要挂载我们自定义的配置文件,mysql不需要,直接改在mysql自己携带的配置文件就可以了

4.1 nacos配置

然后访问http://8.149.247.207:8848/nacos/

默认账户密码都是nacos

进去修改

java 复制代码
        username: nacos
        password: nacosckoj_8

创建命名空间ckoj

然后是修改所有的bootstrap.yml中的命名空间和nacos的IP地址--->都修改为云服务器的内网ip

java 复制代码
spring:
  application:
    name: oj-gateway
  profiles:
    active: local
  cloud:
    nacos:
      discovery:
        namespace: daa14732-226e-45aa-b977-afb68b8693f7
        server-addr: http://172.30.125.51:8848
        username: nacos
        password: nacosckoj_8
        ip: ${HOST_IP}
      config:
        namespace: daa14732-226e-45aa-b977-afb68b8693f7
        server-addr: http://172.30.125.51:8848
        file-extension: yaml
        username: nacos
        password: nacosckoj_8

比如这是网关的bootstrap.yml

这里的ip写为云服务器的内网ip

然后是nacos上面的配置,和本地的一样就可以了
然后修改nacos上面配置对应的ip地址--》也是内网ip

比如redis,mysql,Rabbitmq,elasticsearch,xxl-job的ip

或者不改ip,直接用localhost也没事,因为都是部署在一个机器的?---》不行,因为写127.0.0.1的话就是容器本身了

这里建议用内网ip,如果是公网ip的话,容器就会去公网访问端口号----》还要开放端口号

因为访问公网 IP 会走外网路由(即使是本机公网 IP,数据包会绕网卡)

哪怕访问的是本机公网 IP,数据包仍会走 "外网链路",会被这两层拦截机制检查,不开放就会被拒绝

需要开放对应端口号--》最好不要这样,不然会被攻击的,因为这些端口号比较特殊

java 复制代码
sandbox:
  docker:
    host: tcp://172.30.125.51:2375

注意这里要改为dockerr0的ip,其实不改应该也没事的

java 复制代码
ip addr show docker0

这里的172.17.0.1就是docker0

java 复制代码
sandbox:
  docker:
    host: tcp://172.17.0.1:2375

然后是对象存储的秘钥和地址,过期了的要重新申请一个

5. 其他组件的docker-compose

java 复制代码
  oj-xxl-job-server:
    container_name: oj-xxl-job-server
    image: xuxueli/xxl-job-admin:2.4.0
    # 设置连接MySQL的URL、用户名和密码等配置。
    environment:
      - SPRING_DATASOURCE_URL=jdbc:mysql://oj-mysql-server:3306/xxl_job?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&serverTimezone=Asia/Shanghai
      - SPRING_DATASOURCE_USERNAME=ojtest
      - SPRING_DATASOURCE_PASSWORD=123456
    # 假设xxl-job监听在8080端口
    ports:
      - "8080:8080"
    # 依赖于 oj-mysql-server 服务,并在其状态为健康时启动。
    depends_on:
      oj-mysql-server:
        condition: service_healthy

  oj-redis-server:
    container_name: oj-redis-server
    image: redis:latest
    ports:
      - "6379:6379"
    volumes:
      - ./redis/data:/data
    # 设置 Redis 的访问密码。
    environment:
      REQUIREPASS: 123456
    healthcheck:
      test: [ "CMD", "redis-cli", "ping" ]
      interval: 10s
      timeout: 5s
      retries: 10

  oj-gateway:
    image: ck/oj-gateway:0.0.1-SNAPSHOT
    # 提供了构建上下文的路径。这意味着Docker将在./bitoj-jar/gateway/目录中寻找构建所需的文件。
    build:
      context: ./ckoj-jar/gateway/
    container_name: oj-gateway
    environment:
      # 时区上海
      TZ: Asia/Shanghai
      HOST_IP: 172.30.125.51
    ports:
      - "19090:19090"
    privileged: true
    depends_on:
      oj-nacos-server:
        condition: service_healthy
      oj-redis-server:
        condition: service_healthy

  oj-nginx-server:
    # 使用 nginx:1.21 镜像。
    image: nginx:1.21
    # 容器名称为 oj-nginx-server
    container_name: oj-nginx-server
    volumes:
      # 配置文件挂载
      - ./nginx/conf/default.conf:/etc/nginx/conf.d/default.conf
      # 前端项目部署核心步骤。这可以用于将一些静态资源(如网页、文件、图片等)从本地主机挂载到容器中,供 Nginx 进行服务。
      - ./nginx/dist:/home/dist
    environment:
      # 时区上海
      TZ: Asia/Shanghai
    # 端口映射
    ports:
      - "80:80"
      - "10030:10030"
      - "443:443"
    privileged: true
    # 表示此服务依赖于 oj-gateway 服务,即 oj-gateway 服务启动后才会启动此服务。
    depends_on:
      - oj-gateway

  oj-elasticsearch-server:
    container_name: oj-elasticsearch-server
    image: elasticsearch:8.5.3
    ports:
      - "9200:9200"
    # 挂载本地目录用于存储 Elasticsearch的数据、插件。
    volumes:
      - ./elasticsearch/es-plugins:/usr/share/elasticsearch/plugins
    # 设置为单节点模式,并限制 Java 虚拟机的内存使用。暂时禁用了Elasticsearch的安全特性
    environment:
      discovery.type: single-node
      ES_JAVA_OPTS: "-Xms256m -Xmx256m"
      xpack.security.enabled: false
    # 通过执行 curl 命令检查 Elasticsearch 的集群健康状态。
    healthcheck:
      test: [ "CMD", "curl", "-s", "http://localhost:9200/_cluster/health?wait_for_status=green&timeout=1s" ]
      interval: 30s
      timeout: 5s
      retries: 10

  oj-kibana-server:
    image: kibana:8.5.3
    container_name: oj-kibana-server
    ports:
      - "10010:5601"
    # 依赖于 oj-elasticsearch-server 服务,并在其健康时启动。
    depends_on:
      oj-elasticsearch-server:
        condition: service_healthy
    # 设置系统语言为中文,并指定连接到 Elasticsearch 的 URL
    environment:
      I18N_LOCALE: zh-CN
      ELASTICSEARCH_URL: http://oj-elasticsearch-server:9200

  oj-rabbitMQ-server:
    container_name: oj-rabbitMQ-server
    image: rabbitmq:3.9.13-management
    ports:
      - "5672:5672"
      - "10020:15672"
    volumes:
      - ./rabbit/data:/var/lib/rabbitmq
    # 设置 RabbitMQ 的默认用户名和密码。
    environment:
      RABBITMQ_DEFAULT_USER: admin
      RABBITMQ_DEFAULT_PASS: admin
    healthcheck:
      test: [ "CMD", "rabbitmqctl", "status" ]
      interval: 30s
      timeout: 10s
      retries: 10

  oj-system:
    image: ck/oj-system:0.0.1-SNAPSHOT
    build:
      context: ./ckoj-jar/system/
    container_name: oj-system
    environment:
      # 时区上海
      TZ: Asia/Shanghai
      HOST_IP: 172.30.125.51
    ports:
      - "9201:9201"
    privileged: true
    depends_on:
      oj-nacos-server:
        condition: service_healthy
      oj-redis-server:
        condition: service_healthy
      oj-elasticsearch-server:
        condition: service_healthy

  oj-friend:
    image: ck/oj-friend:0.0.1-SNAPSHOT
    build:
      context: ./ckoj-jar/friend/
    container_name: oj-friend
    environment:
      # 时区上海
      TZ: Asia/Shanghai
      HOST_IP: 172.30.125.51
    ports:
      - "9202:9202"
    privileged: true
    depends_on:
      oj-nacos-server:
        condition: service_healthy
      oj-redis-server:
        condition: service_healthy
      oj-elasticsearch-server:
        condition: service_healthy
      oj-rabbitMQ-server:
        condition: service_healthy

  oj-job:
    image: ck/oj-job:0.0.1-SNAPSHOT
    build:
      context: ./ckoj-jar/job/
    container_name: oj-job
    environment:
      # 时区上海
      TZ: Asia/Shanghai
      HOST_IP: 172.30.125.51
    ports:
      - "9203:9203"
    privileged: true
    depends_on:
      oj-nacos-server:
        condition: service_healthy
      oj-redis-server:
        condition: service_healthy

  oj-judge:
    image: ck/oj-judge:0.0.1-SNAPSHOT
    build:
      context: ./ckoj-jar/judge/
    container_name: oj-judge
    # 将本地目录挂载到容器内的用户代码存储目录
    volumes:
      - /user-code-pool:/user-code-pool
    environment:
      # 时区上海
      TZ: Asia/Shanghai
      HOST_IP: 172.30.125.51
    privileged: true
    depends_on:
      oj-nacos-server:
        condition: service_healthy
      oj-rabbitMQ-server:
        condition: service_healthy

里面的HOST_IP就是在nacos先注册显示的ip,就弄为云服务器内网ip就可以了

因为原来部署是两个oj-judge,所以HOST_IP要不一样,这里我们只部署一个HOST_IP,所以HOST_IP就用一个就可以了

所有的微服务都要配置HOST_IP

6. 后端部署

java 复制代码
mvn clean package -DskipTests

后端打包

java 复制代码
cd D:\spring-project\ck-oj\deploy\test\sh
.\copy.ps1

然后执行这个脚本,用PowerShell

然后是上传相关的文件

如果只有组件,我们是可以docker compose up -d,直接拉取镜像

但是有了微服务的话,就不可以了,是因为镜像这一块,因为mysql和nacos镜像不是我们自定义的,不需要构建这两个镜像的,但是这些微服务的镜像我们是没有的,所以要先构建这些微服务的镜像才可以构建容器

先用docker compose build来构建镜像---》java服务

java 复制代码
docker compose build

直接这个命令,然后就可以根据docker compose .yml来构建镜像了

先不要慌着docker compose up -d

6.1 nginx配置修改

java 复制代码
upstream ckoj {
    server 172.30.125.51:19090;
}

改为这样就可以了

java 复制代码
docker compose up -d

7. 测试

给网关添加增加管理员接口的白名单

java 复制代码
security:
  ignore:
    whites: 
      - /**/login
      - /friend/user/sendCode
      - /friend/user/loginOrRegister
      - /**/semiLogin/**
      - /system/sysUser/add

访问http://8.149.247.207:10030/就可以访问b端接口了

http://8.149.247.207:80就可以进入c端了

开放端口10030,80,19090

还有一点要注意,oj-system也有elasticsearch的配置,以前都没配置

创建管理员用户

总结

相关推荐
刘一说1 小时前
Nacos 配置加载优先级详解:Spring Cloud Alibaba 微服务配置管理的核心机制
微服务·云原生·架构
v***44671 小时前
【语义分割】12个主流算法架构介绍、数据集推荐、总结、挑战和未来发展
算法·架构
赖small强1 小时前
【Linux】地平线X3M系统启动全流程深度解析
linux·linux系统引导·linux系统启动·文件系统挂载
逻极1 小时前
从单体到微服务:我们如何将Python Web应用性能提升3倍
python·微服务·web
y***n6141 小时前
SpringCloud系列教程:微服务的未来(十四)网关登录校验、自定义过滤器GlobalFilter、GatawayFilter
java·spring cloud·微服务
g***96901 小时前
Linux下启动redis
linux·redis·bootstrap
杜子不疼.1 小时前
【Linux】进程概念(六):地址空间核心机制
linux·运维·服务器
z***3351 小时前
SpringCloud 系列教程:微服务的未来(二)Mybatis-Plus的条件构造器、自定义SQL、Service接口基本用法
spring cloud·微服务·mybatis
APIshop1 小时前
1688 拍立淘接口 item_search_img 返回值超细说明
linux·运维·服务器