承接上文k8s自动化运维十三-国产麒麟操作系统安装minikube
基于麒麟系统做如下安装
安装docker-compose
# docker-compose-Linux-aarch64
sudo curl -L "https://github.com/docker/compose/releases/download/v2.2.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose复制
docker-compose安装nacos
# https://hub.docker.com/r/nacos/nacos-server
git clone --depth 1 https://github.com/nacos-group/nacos-docker.git
# 修改版本号 nacos/nacos-server:2.0.4-slim 支持arm64架构
# https://hub.docker.com/r/nacos/nacos-server/tags?page=1&ordering=name&name=2.0.4-slim
vim example/.env
NACOS_VERSION=2.0.4-slim
docker-compose -f example/standalone-derby.yaml up -d复制
查看启动情况 docker ps
安装docker mysql 8
# mysql/mysql-server 该镜像支持aarch64架构
docker run --name mysql -e MYSQL_ROOT_PASSWORD=testDB! -v "/data/nfs-client/mysql/my.cnf":"/etc/mysql/my.cnf" -v "/data/nfs-client/mysql/data":/var/lib/mysql --restart=always -p 3306:3306 -d mysql/mysql-server
cat data/nfs-client/mysql/my.cnf
[mysqld]
# 表名不区分大小写 mysql8及以上仅支持初始化的时候配置,不支持启动好之后再更改,否则会报 ERROR] [MY-011087] [Server] Different lower_case_table_names settings for server ('1') and data dictionary ('0').
lower-case-table-names=1
# mysql:5.7 支持x86-64,不支持arm64
docker run --name mysql -e MYSQL_ROOT_PASSWORD=testDB! -v "/data/nfs-client/mysql/data":/var/lib/mysql -v "/data/nfs-client/mysql/conf.d":/etc/mysql/conf.d -v "/data/nfs-client/mysql/mysql.conf.d":/etc/mysql/mysql.conf.d --restart=always -p 3306:3306 -d mysql:5.7
cat data/nfs-client/mysql/mysql.conf.d/galaxy.cnf
[mysqld]
lower_case_table_names=1
max_connections = 1000
max_allowed_packet=50M
wait_timeout=288000
interactive_timeout = 288000复制
mysql不允许连接异常
java.sql.SQLException: null, message from server: "Host '172.18.0.1' is not allowed to connect to this MySQL server"
# 登录数据库实例
mysql -u root -p
use mysql;
select host from user where user='root';
update user set host = '%' where user ='root';
flush privileges;复制
MySQL 8: Public Key Retrieval is not allowed
Caused by: com.mysql.cj.exceptions.UnableToConnectException: Public Key Retrieval is not allowed
数据库url中添加allowPublicKeyRetrieval=true&useSSL=false
# 完整url
jdbc:mysql://192.168.49.1:3306/xibaoxiao-galaxy?serverTimezone=Asia/Shanghai&characterEncoding=utf8&allowPublicKeyRetrieval=true&useSSL=false&zeroDateTimeBehavior=convertToNull复制
清理磁盘空间
查看大目录
du -sh * |sort -rn | head
复制
进入大目录查看大文件
cd /var/lib
# 查看当前目录下大于100M的文件
find . -type f -size +100M -print0 | xargs -0 du -h | sort -nr
# 如果是日志文件
cat /dev/null > xxxx.log复制
删除无用的docker镜像
docker image rm $(docker image ls | grep "<none>" | awk -F " " '{print $3}')
# grep 筛选指定的镜像
# awk -F " " 以空格为分隔符 切分 获取镜像id值复制
打通k8s service与pod之间的网络
创建一个service
cat gateway.yaml
apiVersion: v1
kind: Service
metadata:
labels:
app: xibao-gateway
name: xibao-gateway
namespace: xibao
spec:
ports:
- name: 2pdycx1111
nodePort: 30002
port: 8092
protocol: TCP
targetPort: 8092
selector:
app: xibao-gateway
sessionAffinity: None
type: NodePort
status:
loadBalancer: {}复制
访问service的端口转发到pod内的进程上去
# service名称比如nginx-service,service的端口30084,对应pod内nginx服务中9000进程
kubectl port-forward --address 0.0.0.0 service/nginx-service 30084:9000复制
k8s下载镜像报错
connect: no route to host
minikube的ip是192.168.49.2,与172.17.28.172不是同一网段,镜像换成192.148.49.1:5000/xxxxx就可以了。
k8s访问docker registry 安全限制问题
# 启动minikube的时候,添加insecure-registry,允许k8s http协议访问192.168.49.1:5000
minikube start --driver=docker --image-mirror-country=cn --registry-mirror=https://kaakiyao.mirror.aliyuncs.com --insecure-registry=192.168.49.1:5000复制
查询git每天指定时间段内的提交记录
# 查询下午18点或早上9点之前代码提交记录 (获取每次提交记录中的小时,判断是否在指定范围内)
git log --author="mengfanxiao" --pretty=format:'%h %cn %cd %s' --date='format:%Y-%m-%d %H:%M:%S' | \
awk '{hour=0+substr($4,0,2); if(hour>18 || hour<9) printf "%-10s %-15s %-12s %-10s %-10s\n", $1, $2, $3, $4, $5 }'
# 指定日期范围
git log --committer="mengfanxiao" --after="2019/09/15 18:00:00" --before="2022/09/15 09:30:00" --pretty=format:"%an %ad : %s" --date=short --no-merges --reverse复制
gitlab-runner
# 支持aarch64架构的二进制可执行文件
# 使用root权限,否则可能监听不到gitlab提交的job
sudo curl -L --output /usr/local/bin/gitlab-runner "https://gitlab-runner-downloads.s3.amazonaws.com/latest/binaries/gitlab-runner-linux-arm64"复制
通过域名访问gitlab代码库下载代码慢的问题
可以手动将代码zip下载下来,然后上传到服务器的/usr/local/bin/builds/wEhaMhYg/0/galaxy/目录下。
文章转载自平凡人笔记,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【MySQL 30周年庆】MySQL 8.0 OCP考试限时免费!教你免费领考券
墨天轮小教习
2979次阅读
2025-04-25 18:53:11
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
严少安
852次阅读
2025-04-25 15:30:58
【活动】分享你的压箱底干货文档,三篇解锁进阶奖励!
墨天轮编辑部
496次阅读
2025-04-17 17:02:24
MySQL 9.3 正式 GA,我却大失所望,新特性亮点与隐忧并存?
JiekeXu
436次阅读
2025-04-15 23:49:58
3月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
373次阅读
2025-04-15 14:48:05
MySQL 8.0 OCP 1Z0-908 考试解析指南(二)
JiekeXu
292次阅读
2025-04-30 17:37:37
记录MySQL数据库的一些奇怪的迁移需求!
陈举超
279次阅读
2025-04-15 15:27:53
SQL优化 - explain查看SQL执行计划(下)
金同学
274次阅读
2025-05-06 14:40:00
MySQL 8.0 OCP 1Z0-908 考试题解析指南
青年数据库学习互助会
257次阅读
2025-04-30 12:17:54
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
数据库运维之道
248次阅读
2025-04-28 11:01:25