提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
文章目录
- 前言
- [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的配置,以前都没配置

创建管理员用户