Hi there 👋
📫 除了编程之外,我对开源项目非常感兴趣,虽然没有参与过开源项目的贡献和维护,但一直在努力学习和积累经验,希望有一天能够为开源项目做出自己的贡献。同时,在工作中充分利用开源社区资源,提高编码技能和解决问题的能力。
🌱 目前我居住在一个美丽的城市,这里有着浓郁的文化氛围和美食文化,也有着现代化的技术环境和创新精神。我感到非常幸运能够在这里工作和生活,享受着快乐而充实的时光。
00 前言 最近接到了一个需求,要把 RGB 的图片转为 CMYK 的颜色模式,用于印刷。 网上对于 RGB 转为 CMYK 的资料较少,Java 也没有内置的方法。主流方法有两种,一种是手搓强转,另一种则是借助 ICC 文件来转换。 该需求对于分辨率、物理尺寸有一定的要求,且原途径就是通过 PS 处理的,正好用同样的 ICC 文件转换,能达到相对一致的颜色要求。 01 色彩空间转换 1.1 关键概念 RGB 模式是以色光三原色为基础建立的色彩模式,红、绿、蓝,是电脑、手机、投影仪、电视等屏幕显示的最佳颜色模式。 CMYK(青色、品红色、黄色、黑色)是印刷材料的色彩空间。CMY 是 3 种印刷油墨名称的首字母:青色 Cyan、洋红色 Magenta、黄色 Yellow,由于目前制造工艺还不能造出高纯度的油墨,CMY 相加实际得到的是深灰色或深褐色,故加入纯黑色。 ICC Profile 色彩特性文件,是一组用来描述色彩空间的特性的数据集合,因由国际色彩联盟(ICC)主持制定其规范而得名。RGB 转为 CMYK 就是把 RGB 值转为 CMYK 值。 像素(Pixel)是指构成图片的小色点。 分辨率(单位 DPI)是指每英寸(Inch)上的像素数量,++1 英寸 = 2.54 厘米++。 像素相同时,分辨率越高则像素密度越大,实际打印尺寸越小,图像也越细腻。 1.2 转换步骤 首先,引入 JAI(Java Advanced Imaging),最新版 1.1.3,这个库好几年没更新了: <dependency> <groupId>javax.media.jai</groupId> <artifactId>com.springsource.javax.media.jai.codec</artifactId> <version>1.1.3</version> </dependency> <!-- 这个库只用到了 TIFF 的静态变量,可以不引入 --> <dependency> <groupId>com....
碎碎念 在 Springboot 中,跨服务的文件传输需要考虑性能、一致性、安全性等问题。 对于 Excel 文件的上传下载,是否在对外服务层进行解析和封装会更好呢? 对于其他类型的文件,可以考虑独立出一个文件服务,以实现服务解耦和更好的水平扩展。 01 SpringBoot 图片上传 普通文件上传 普通的文件上传,直接使用 MultipartFile 类型声明参数即可: @RestController public class FileUploadController { @PostMapping("/upload") public ResponseEntity<String> handleFileUpload( @RequestParam("file") MultipartFile file, @RequestParam("param1") String param1, @RequestParam("param2") String param2) { if (file.isEmpty()) { return ResponseEntity.badRequest().body("请选择文件上传"); } // 这里可以添加文件上传的业务逻辑,比如保存文件到服务器 return ResponseEntity.ok("文件上传成功"); } } 如果是多文件上传,则使用 MultipartFile[] 数组。 如果参数过多,可以使用 @SpringQueryMap 把参数放在类里面,这是 OpenFeign 提供的类似 @QueryMap 功能,支持把 Query 参数封装到对象中: @RestController public class FileUploadController { @PostMapping("/upload") public ResponseEntity<String> handleFileUpload( @RequestParam("file") MultipartFile file, @Validated @SpringQueryMap QueryDTO req) { // do sth....
问题是什么呢? 在停止 Tomcat 后,无法再次启动。 尝试使用 catalina.sh 启动时出现如下警告: [R@K tomcat/bin]$ ./catalina.sh start Using CATALINA_BASE: /app/tomcat Using CATALINA_HOME: /app/tomcat Using CATALINA_TMPDIR: /app/tomcat/temp Using JRE_HOME: /app/j2sdk1.8.0/jre Using CLASSPATH: /app/tomcat/bin/bootstrap.jar:/app/tomcat/bin/tomcat-juli.jar Using CATALINA_OPTS: -javaagent:/app/skywalking/skywalking-agent/skywalking-agent.jar -Dskywalking.agent.service_name=springx-web -Dskywalking.collector.backend_service=192.168.1.122:11800 Using CATALINA_PID: /app/tomcat/bin/CATALINA_PID Existing PID file found during start. Tomcat appears to still be running with PID 22832. Start aborted. # 这里说 Tomcat 已经运行了,PID 为 22832 If the following process is not a Tomcat process, remove the PID file and try again: UID PID PPID C STIME TTY TIME CMD # 可是这里并没有任何进程 输出的日志显示,PID 已存在。根据部分 Linux 应用的习惯可知,Tomcat 启动后,会将其 PID 记录在一个文件中,再次启动时会主动检测该文件,以判断是否重复启动。...
00 碎碎念 为什么使用 Docker 去搭建 Jenkins 呢? 主要原因是个人频繁切换环境,有时候在本地虚拟机玩,有时候会在云服务器上折腾,渐感被自己折磨过多了,因此希望能够创建一个配置文件,以便一键启动并快速方便地使用。另外,自己经常在其他地方装环境,公司的服务也比较老,一但要迁移,用 Docker 就很方便。所以,使用 Docker 是很适合的。 网上那么多一样的文章,为什么要写这篇呢? 虽然说这篇文章是作为笔记的,但是因为自己在使用网上的方法安装的时候,遇到几个问题,尝试了很多方法才成功,所以想要记录一下,以备不时之需。 01 Docker Compose 安装 以下是测试过的,能正常部署和使用 Jenkins 的 Docker Compose 配置,部分参数请按需调整。 version: '3.9' services: jenkins: # 镜像选择了 jdk17 最新版,可自行选择 image: jenkins/jenkins:jdk17 container_name: jenkins # 重启策略:除非手动停止,否则出错会无限重启 restart: unless-stopped # 指定用户 uid:gid(`用户id`:`宿主机的docker组id`,跟文件权限有关) user: 1000:995 ports: # 8080 为 Jenkins 的 Web 端口 - 9001:8080 # 50000 为代理节点与主服务器的通信端口? - 50001:50000 volumes: # 同步宿主机的时间 - /etc/timezone:/etc/timezone - /etc/localtime:/etc/localtime # Jenkins 数据目录映射出来,方面操作和备份 - ....
碎碎念 由于网络原因,我们不得不使用一些手段,以疏通或者加速它。 在 CMD/PowerShell 终端配置代理,可以允许整个命令行得到代理。 使用 git config 配置代理,则仅支持 git 自身获得代理。 CMD 设置代理 Windows 的 cmd 使用 set 命令来配置: > set http_proxy=http://127.0.0.1:1080 # Or > set https_proxy=https://127.0.0.1:1080 这种方式,可以进行终端全局的代理。 Windows 还有 PowerShell 终端,也是类似的。 PowerShell 设置代理 PowerShell 配置方式比较特殊,但同样是设置全局变量 HTTP_PROXY/HTTPS_PROXY(不区分大小写): > $env:HTTP_PROXY="http://127.0.0.1:1080" # Or > $env:HTTPS_PROXY="https://127.0.0.1:1080" 注: 终端配置的方式,每次关闭之后,都要重新配置。除了写一段初始化脚本,还可以直接配置 git 的全局代理。 Git Bash 设置代理 在 Git Bash 中,可以通过 git config 设置 HTTP 代理: > git config --global http.proxy "http://127.0.0.1:1080" # Or > git config --global https....
01 搭建私服的初衷 1.1 为什么搭建私服? 使用 Maven 管理项目依赖时,通常会从 Maven 仓库拉取第三方依赖,此时只需要配置公共仓库源即可。 但是,如果需要使用公司内部依赖,需要同时使用第三方依赖和私有依赖,这就需要搭建私服,用以存储私有组件库。 搭建私服,可以实现如下功能: 共享私有依赖,保护敏感信息 保存依赖版本,避免依赖变化或升级受影响 提升代理速读,缓存常用依赖到私服 自定义配置策略、规则、权限等 2.2 为什么选择 Nexus ? 常见仓库管理有如下几种: Nexus Repository Manager:Nexus 是一个广泛使用的 Maven 仓库管理器,它提供了丰富的功能,包括支持 Maven、Gradle、Ivy 等构建工具,具有强大的缓存和代理能力,以及用户权限控制、部署规则等功能。 Artifactory:Artifactory 是另一个流行的 Maven 仓库管理器,它支持多种构建工具,提供了企业级的功能,例如高度可定制的权限控制、智能缓存和复制、跨数据中心复制、虚拟仓库等。 Archiva:Archiva 是一个轻量级的 Maven 仓库管理器,它提供了基本的 Maven 仓库功能,例如部署、下载和缓存。虽然功能相对较少,但易于安装和使用,适用于小型项目或简单的私有仓库需求。 选择 Nexus 一来是满足需求,需要的功能都包含,二来是比较熟悉。其他管理系统也都可以,视情况选择即可。 02 使用 Docker-Compose 搭建 2.1 Docker-Compose 搭建 首先,编写 docker-compose.yaml: version: '3.9' services: nexus: image: sonatype/nexus3:latest #image: sonatype/nexus3:3.56.0 container_name: nexus3 restart: always ports: - 10240:8081 volumes: - ./nexus-data:/nexus-data 然后,创建目录 ./nexus-data 映射数据(不需要备份的就不需要啦),因为需要配置目录权限,所以这里要手动创建目录:...
碎碎念 对于普通的系统开发,很少会对数据进行细粒度的权限控制。 但是,在某些需要提供给第三方数据的场景中,要么会直接提供基础数据,要么会提供仅有部分权限的账户。如果是直接提供账户,就需要对账户进行比较精细的权限限制。 在 mysql 库中,有很多的系统配置表。其中,user 表中存储的是全局的权限,更细粒度的权限分别存储在其他表中。 01 权限 虽然在上一篇《MySQL 用户管理:创建、权限配置和删除》 中提到,修改权限可以直接修改表(update 操作),但是,有些权限涉及其他表,直接修改表不方便,也不建议。 当然,MySQL 已经为权限提供了 GRANT 和 REVOKE 命令,用于授权和回收权限。 常见权限名称如下,使用别名授权,就不需要直接 update 数据库了: 权限别名 权限列名 权限范围 SELECT select_priv Tables or columns INSERT insert_priv Tables or columns UPDATE update_priv Tables or columns DELETE delete_priv Tables CREATE create_priv Databases, tables, or indexes DROP drop_priv Databases, tables, or views INDEX index_priv Tables … … … 具体参考官方文档:6.2.2 Privileges Provided by MySQL 1.1 全局权限(user) 全局权限存储在 mysql.user 表中,作用于 MySQL 的所有数据库,除了 root,新建用户默认都没有权限(都是 N)...
碎碎念 遇到过的很多小伙伴,无论在开发环境,还是在正式环境,都是“一键 ROOT”。包括但不限于 Linux 服务器、MySQL 数据库或者其他中间件,一律使用 ROOT 账户登录使用。 虽然这么做,可以减少权限等其他不重要的问题,省去很多麻烦,但是,我觉得这个习惯并不好。如果是正式环境,应该尽量避免这种情况。而且,真正需要自己去配置这些的时候,整个过程都会磕磕绊绊。 作为一个爱折腾的小码农,还是忍不住要弄它几下的。 01 创建用户 1.1 查询用户 MySQL 所有的用户信息,均保存在数据库名为 mysql 的 user 表中。 mysql> select user, host, plugin from mysql.user ; +------------------+-----------+-----------------------+ | user | host | plugin | +------------------+-----------+-----------------------+ | root | % | mysql_native_password | | mysql.infoschema | localhost | caching_sha2_password | | mysql.session | localhost | caching_sha2_password | | mysql.sys | localhost | caching_sha2_password | | root | localhost | mysql_native_password | +------------------+-----------+-----------------------+ 从上面的结果可以看到,除了几个内置的账户,默认只有 root 用户。...
01 概述 1.1 环境 CentOS 8 $ docker --version Docker version 20.10.11, build dea9396 $ docker-compose --version Docker Compose version v2.16.0 1.2 Docker 安装 MySQL 的初始化原理 MySQL Docker 官方介绍:Initializing a refsh instance When a container is started for the first time, a new database with the specified name will be created and initialized with the provided configuration variables. Furthermore, it will execute files with extensions ++.sh, .sql and .sql.gz++ that are found in /docker-entrypoint-initdb....
00 Windows 下的路由 路由是什么? 路由是指在计算机网络中将数据包从源地址传输到目标地址的过程,通过路由器根据网络拓扑和路由表中的信息进行决策和转发。 Windows 的路由命令格式如下: Manipulates network routing tables. 操作网络路由表 ❯ route /? ROUTE [-f] [-p] [-4|-6] command [destination] [MASK netmask] [gateway] [METRIC metric] [IF interface] -f:清除所有路由表项。如果与其中一个命令一起使用,则在运行命令之前清除表。 -p:与 ADD 命令结合使用,标识添加为永久路由 METRIC:跃点数,网络接口顺序,值越小越优先(会自动调整) command:命令,有四个可选命令,分别对应路由的增删改查 PRINT:打印路由 ADD:添加路由 DELETE:删除路由 CHANGE:修改路由 01 查看路由表(print) 查看路由的命令格式如下: route print:查看所有 route print -4:查看 ipv4 路由表 route print -6:查看 ipv6 路由表 route print 192.168.*:查看匹配的路由 示例:查看 172.16.30 相关的路由信息 ❯ route print -4 172.16.30* =========================================================================== Interface List 48...00 15 00 00 00 00 ....