分享

花了20天的时间给粉丝整理的一套“最全“的Java求职笔记(十一)

 LRyab博客网 2021-09-21
大家好,我是小编LRyab,公众号LRyab博客网,LRyab博客网是分享一些个人成长、思考方向、个人感悟、职业规划,博客涵盖java技术 vue. html. css.前端技术spring全家桶. linux运维技术在365天把你打造出来一个全栈工程师!

 点击下方卡片关注公众号,每天分享一篇技术干货!

前言:前几天有粉丝问我,网上java面试题总是参差不齐,希望我为他整理一套全面的java面试题,并且这套java面试题有个要求,必须能够让他20天就能看完这些面试题,他说现在很多面试题我看都得看3个月才能看完,然后我才能去找工作,但是自己得时间有限所以想让我帮他总结一套万能面试java求职笔记。接下来我将会至少分为12个章节进行阐述这套Java求职笔记,感兴趣的可以坚持看完!觉得不错的可以点个赞。

1为什么写这套Java求职笔记

      很早的时候我就想写一些Java求职方向的一些文章,由于很长时间耽搁了加上,有粉丝后台问我,可不可以帮他总结一些java求职笔记,他看了很多Java技术有很多技术,很迷茫不知道学哪些,我笑着说,不要着急,无论你到什么时候你都会迷茫,因为技术一直在更新,谢谢你信任我,解救你的迷茫唯一办法就是多看LRyab博客,就是这样我带着粉丝的问题,开始编写了这套Java求职笔记,看完这套求职笔记,我相信很多人都会找到属于自己的心仪工作。

2DevOps&Docker容器化技术知识大纲

3DevOps&Docker容器化技术

3.1DevOps简介

DevOps 就是开发(Development)、测试(QA)、运维(Operations)这三个领域的合并。

DevOps是一种思想、一组最佳实践、以及一种文化。DevOps落地实施,从组织架构、设计人员、流程、人员分工、人员技能到工具,变化很大,要求很高,完全颠覆了现有的开发运维模式,建设风险很高。

DevOps落地困境包括:

  • 涉及的部门多(开发中心、质量控制部门、生产运行部门);

  • 流程改造复杂;

  • 责任边界需要重新划分;

  • 自动化是核心问题。

如下图,传统开发和运维之间存在一堵墙,开发人员想改变而运维人员想要稳定。另外,传统开发工具与运维工具也存在一堵墙,并没有打通成为一条工具链。

3.2CICD

持续集成(Continuous Integration ,CI)

在传统软件开发过程中,集成通常发生在每个人都完成了各自的工作之后。在项目尾声阶段,通常集成还要痛苦的花费数周或者数月的时间来完成。持续集成是一个将集成提前至开发周期的早期阶段的实践方式,让构建、测试和集成代码更经常反复地发生。

开发人员通常使用一种叫做CI Server 的工具来做构建和集成。持续集成要求史蒂夫和安妮能够自测代码。分别测试各自代码来保证它能够正常工作,这些测试通常被称为单元测试(Unit tests)。

代码集成以后,当所有的单元测试通过,史蒂夫和安妮就得到了一个绿色构建(green build)。这表明他们已经成功地集成在一起,代码正按照测试预期地在工作。然而,尽管集成代码能够成功地一起工作了,它仍未为生产做好准备,因为它没有在类似生产的环境中测试和工作。在下面持续交付部分你可以了解到持续集成后面发生了什么。

持续交付(Continuous Delivery)

Continuous Delivery (CD) 持续交付是持续集成的延伸,将集成后的代码部署到类生产环境,确保可以以可持续的方式快速向客户发布新的更改。如果代码没有问题,可以继续手工部署到生产环境中。

持续部署(Continuous Deploy)

如果真的想获得持续交付的好处,应该尽早部署到生产环境,以确保可以小批次发布,在发生问题时可以轻松排除故障。于是有了持续部署。

我们通常将这个在不同环境发布和测试的过程叫做部署流水线

持续部署是在持续交付的基础上,把部署到生产环境的过程自动化。

3.3DevOps 与 CICD的区别及联系

DevOps是CICD思想的延伸,CICD是DevOps的基础核心,如果没有CICD自动化的工具和流程,DevOps是没有意义的。

4Docker容器化技术

1.Docker能干什么?

首先,Docker是容器技术的一种实现。

  • 简化配置:源代码、运行环境、配置都能够打包到一个容器里,这个容器可以运行在不同的环境里,这样开发、测试、生产环境会保持高度一致。

  • 代码流水化管理

  • 整合服务器

  • 调试能力

  • 提升开发效率

  • 多租户

  • 隔离应用

  • 快速部署

什么是容器

  • 对软件及其依赖的标准化打包

  • 能够实现应用之间相互隔离

  • 共享同一个OS Kernel

  • 可以运行在很多主流操作系统上

4.1Docker常用命令

1、Docker容器信息##查看docker容器版本

docker version

##查看docker容器信息

docker info

##查看docker容器帮助

docker --help

2、镜像操作

2.1、镜像查看

##列出本地images

docker images

##显示镜像完整信息

docker images --no-trunc

2.2、镜像搜索

##搜索仓库MySQL镜像

docker search mysql

## --filter=stars=600:只显示 starts>=600 的镜像

docker search --filter=stars=600 mysql

## --no-trunc 显示镜像完整 DESCRIPTION 描述

docker search --no-trunc mysql

## --automated :只列出 AUTOMATED=OK 的镜像

docker search --automated mysql

2.3、镜像下载

##下载Redis官方最新镜像,相当于:docker pull redis:latest

docker pull redis

##下载仓库所有Redis镜像

docker pull -a redis

##下载私人仓库镜像

docker pull bitnami/redis

2.4、镜像删除

##单个镜像删除,相当于:docker rmi redis:latest

docker rmi redis

##强制删除(针对基于镜像有运行的容器进程)

docker rmi -f redis

##多个镜像删除,不同镜像间以空格间隔

docker rmi -f redis tomcat nginx

##删除本地全部镜像

docker rmi -f $(docker images -q)

2.5、镜像构建

##(1)编写dockerfile

cd /docker/dockerfile

vim mycentos

##(2)构建docker镜像

docker build -f /docker/dockerfile/mycentos -t mycentos:1.1

3、容器操作

提示:对于容器的操作可使用CONTAINER ID 或 NAMES。

3.1、容器启动

##新建并启动容器,参数:-i 以交互模式运行容器;-t 为容器重新分配一个伪输入终端;--name 为容器指定一个名称

docker run -i -t --name mycentos

##后台启动容器,参数:-d 已守护方式启动容器

docker run -d mycentos

注意:此时使用"docker ps -a"会发现容器已经退出。这是docker的机制:要使Docker容器后台运行,就必须有一个前台进程。解决方案:将你要运行的程序以前台进程的形式运行。

##启动一个或多个已经被停止的容器

docker start redis

##重启容器

docker restart redis

3.2、容器的进入与退出

##使用run方式在创建时进入

docker run -it centos /bin/bash

##关闭容器并退出

exit

##仅退出容器,不关闭

快捷键:Ctrl + P + Q

##直接进入centos 容器启动命令的终端,不会启动新进程,多个attach连接共享容器屏幕,参数:--sig-proxy=false 确保CTRL-D或CTRL-C不会关闭容器

docker attach --sig-proxy=false centos

##在 centos 容器中打开新的交互模式终端,可以启动新进程,参数:-i 即使没有附加也保持STDIN 打开;-t 分配一个伪终端

docker exec -i -t centos /bin/bash

##以交互模式在容器中执行命令,结果返回到当前终端屏幕

docker exec -i -t centos ls -l /tmp

##以分离模式在容器中执行命令,程序后台运行,结果不会反馈到当前终端

docker exec -d centos touch cache.txt

3.3、查看容器

##查看正在运行的容器

docker ps

##查看正在运行的容器的ID

docker ps -q

##获取镜像redis的元信息

docker inspect redis

##获取正在运行的容器redis的 IP

docker inspect --format='{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' redis

3.4、容器的停止与删除

##停止一个运行中的容器

docker stop redis

##杀掉一个运行中的容器

docker kill redis

##删除一个已停止的容器

docker rm redis

##删除一个运行中的容器

docker rm -f redis

##删除多个容器

docker rm -f $(docker ps -a -q)

docker ps -a -q | xargs docker rm

## -l 移除容器间的网络连接,连接名为 db

docker rm -l db

## -v 删除容器,并删除容器挂载的数据卷

docker rm -v redis

3.5、生成镜像

##基于当前redis容器创建一个新的镜像;参数:-a 提交的镜像作者;-c 使用Dockerfile指令来创建镜像;-m :提交时的说明文字;-p :在commit时,将容器暂停

docker commit -a="DeepInThought" -m="my redis" [redis容器ID] myredis:v1.1

3.6、容器与主机间的数据拷贝

##将rabbitmq容器中的文件copy至本地路径

docker cp rabbitmq:/[container_path] [local_path]

##将主机文件copy至rabbitmq容器

docker cp [local_path] rabbitmq:/[container_path]/

##将主机文件copy至rabbitmq容器,目录重命名为[container_path](注意与非重命名copy的区别)

docker cp [local_path] rabbitmq:/[container_path]

    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多