首页 文章 精选 留言 我的

精选列表

搜索[JDK 25],共10000篇文章
优秀的个人博客,低调大师

容器常用操作 - 每天5分钟玩转 Docker 容器技术(25

前面讨论了如何运行容器,本节学习容器的其他常用操作。 stop/start/restart 容器 通过docker stop可以停止运行的容器。 容器在 docker host 中实际上是一个进程,docker stop命令本质上是向该进程发送一个 SIGTERM 信号。如果想快速停止容器,可使用docker kill命令,其作用是向容器进程发送 SIGKILL 信号。 对于处于停止状态的容器,可以通过docker start重新启动。 docker start会保留容器的第一次启动时的所有参数。 docker restart可以重启容器,其作用就是依次执行docker stop和docker start。 容器可能会因某种错误而停止运行。对于服务类容器,我们通常希望在这种情况下容器能够自动重启。启动容器时设置--restart就可以达到这个效果。 --restart=always意味着无论容器因何种原因退出(包括正常退出),就立即重启。该参数的形式还可以是--restart=on-failure:3,意思是如果启动进程退出代码非0,则重启容器,最多重启3次。 pause/unpause 容器 有时我们只是希望暂时让容器暂停工作一段时间,比如要对容器的文件系统打个快照,或者 dcoker host 需要使用 CPU,这时可以执行docker pause。 处于暂停状态的容器不会占用 CPU 资源,直到通过docker unpause恢复运行。 删除容器 使用 docker 一段时间后,host 上可能会有大量已经退出了的容器。 这些容器依然会占用 host 的文件系统资源,如果确认不会再重启此类容器,可以通过docker rm删除。 docker rm一次可以指定多个容器,如果希望批量删除所有已经退出的容器,可以执行如下命令: docker rm -v $(docker ps -aq -f status=exited) 顺便说一句:docker rm是删除容器,而docker rmi是删除镜像。 一下学了这么多操作,很有必要做个总结。下一节我们会用一张图来描述容器的状态机。

优秀的个人博客,低调大师

wu-easy-excel-starter 版本:1.2.0-JDK1.8-SNAPSHOT

1.新增注解 EasyFile 注解支持字符串导出为文件 2.新增EasyExcel 注解支持对象导出文件 介绍 wu-easy-excel-starter是一款面向对象的excel、文件导出框架。 实现的功能: 1)针对Java中任何对象直接返回给web,在返回web过程自动将对象转换成想要的数据(Excel、File) 2)前端传一个Excel过来,后端接口接收到的其实已经是Bean了 快速导出excel模块 依赖引入 <dependency> <groupId>com.wu</groupId> <artifactId>wu-easy-excel-starter</artifactId> <version>1.0.1-SNAPSHOT</version> </dependency> 基本用法 @Data public class UseExcel { @EasyExcelFiled(name = "id") private Integer id; @EasyExcelFiled(name = "当前时间") private LocalDateTime currentTime; @EasyExcelFiled(name = "描述") private String desc; @EasyExcelFiled(name = "类型") private String type; } @EasyExcel(fileName = "导出数据") @GetMapping("/run/{size}") public List<UseExcel> run(@PathVariable Integer size) { List<UseExcel> useExcelList = new ArrayList<>(); for (int i = 0; i < size; i++) { UseExcel useExcel = new UseExcel(); useExcel.setCurrentTime(LocalDateTime.MAX); useExcel.setDesc("默认方式导出数据"); useExcel.setId(i); useExcel.setType("默认方式双注解导出"); useExcelList.add(useExcel); } return useExcelList; } 自定义字段注解用法 @Data public class UseExcel { @JSONField(name = "id") private Integer id; @JSONField(name = "当前时间") private LocalDateTime currentTime; @JSONField(name = "描述") private String desc; @JSONField(name = "类型") private String type; } @EasyExcel(fileName = "非原生注解导出数据", filedColumnAnnotation = JSONField.class,filedColumnAnnotationAttribute = "name",multipleSheet = true, limit = 10,sheetShowContext = EasyExcel.SheetShowContext.TEXT) @GetMapping("/run2/{size}") public List<UseExcel> run2(@PathVariable Integer size) { List<UseExcel> useExcelList = new ArrayList<>(); for (int i = 0; i < size; i++) { UseExcel useExcel = new UseExcel(); useExcel.setCurrentTime(LocalDateTime.MAX); useExcel.setDesc("自定义字段注解方式导出数据"); useExcel.setId(i); useExcel.setType("自定义字段注解导出"); useExcelList.add(useExcel); } return useExcelList; } 说明 filedColumnAnnotation 从 JSONField注解的name属性中获取表头并导出数据 multipleSheet 导出的数据分多个sheet(工作簿) limit每个sheet 有10条数据 sheetShowContext每个sheet的名称使用EasyExcel.SheetShowContext.TEXT 中文 自定义字段注解+自定控制器注解用法 @Data public class UseExcel { @JSONField(name = "id") private Integer id; @JSONField(name = "当前时间") private LocalDateTime currentTime; @JSONField(name = "描述") private String desc; @JSONField(name = "类型") private String type; } 自定意义EasyExcel注解 @Target({ElementType.TYPE,ElementType.METHOD}) @Retention(RetentionPolicy.RUNTIME) @Documented @Inherited @EasyExcel(useAnnotation = false,filedColumnAnnotation = JSONField.class) public @interface EasyExcelTemp { /** * 文件名称 * @return String */ @AliasFor(annotation = EasyExcel.class,attribute = "fileName") String fileName(); } 使用方法 @EasyExcelTemp(fileName = "自定义注解导出") @GetMapping("/run4/{size}") public List<UseExcel> run4(@PathVariable Integer size) { List<UseExcel> useExcelList = new ArrayList<>(); for (int i = 0; i < size; i++) { UseExcel useExcel = new UseExcel(); useExcel.setCurrentTime(LocalDateTime.MAX); useExcel.setDesc("自定义注解导出"); useExcel.setId(i); useExcel.setType("自定义注解导出"); useExcelList.add(useExcel); } return useExcelList; } 新增垂直合并excel

资源下载

更多资源
Nacos

Nacos

Nacos /nɑ:kəʊs/ 是 Dynamic Naming and Configuration Service 的首字母简称,一个易于构建 AI Agent 应用的动态服务发现、配置管理和AI智能体管理平台。Nacos 致力于帮助您发现、配置和管理微服务及AI智能体应用。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据、流量管理。Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。

Rocky Linux

Rocky Linux

Rocky Linux(中文名:洛基)是由Gregory Kurtzer于2020年12月发起的企业级Linux发行版,作为CentOS稳定版停止维护后与RHEL(Red Hat Enterprise Linux)完全兼容的开源替代方案,由社区拥有并管理,支持x86_64、aarch64等架构。其通过重新编译RHEL源代码提供长期稳定性,采用模块化包装和SELinux安全架构,默认包含GNOME桌面环境及XFS文件系统,支持十年生命周期更新。

Sublime Text

Sublime Text

Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。

WebStorm

WebStorm

WebStorm 是jetbrains公司旗下一款JavaScript 开发工具。目前已经被广大中国JS开发者誉为“Web前端开发神器”、“最强大的HTML5编辑器”、“最智能的JavaScript IDE”等。与IntelliJ IDEA同源,继承了IntelliJ IDEA强大的JS部分的功能。

用户登录
用户注册