SpringCloud相关问题
SpringCloud什么是SpringCloud?Spring cloud 流应用程序启动器是基于Spring Boot的Spring 集成应用程序,提供与外部系统的集成.Spring cloud Task,一个生命周期短暂的微服务框架,用于快速构建执行有限数据处理的应用程序
什么是微服务?微服务架构是一种架构模式或者说是一种架构风格,它提倡将单一应用程序划分为一组小的服务,每个服务运行在其独立的自己的进程中,服务之间相互协调、互相配合,为用户提供最终价值。服务之间采用轻量级的通信机制互相沟通(通常是基于HTTP的RESTful API),每个服务都围绕着具体的业务进行构建,并且能够被独立的构建在生产环境、类生产环境等。另外,应避免统一的、集中式的服务管理机制,对具体的一个服务而言,应根据业务上下文,选择合适的语言、工具对其进行构建,可以有一个非常轻量级的集中式管理来协调这些服务,可以使用不同的语言来编写服务,也可以使用不同的数据存储 .
SpringCloud有什么优势?使用 Spring Boot 开发分布式微服务时,我们面临以下问题(1)与分布式系统相关的复杂性-这种开销包括网 ...
分布式-CAP定理
cap理论一、什么是分布式系统拿一个最简单的例子,就比如说我们的图书管理系统。之前的系统包含了所有的功能,比如用户注册登录、管理员功能、图书借阅管理等。这叫做集中式系统。也就是一个人干了好几件事。
后来随着功能的增多,用户量也越来越大。集中式系统维护太麻烦,拓展性也不好。于是就考虑着把这些功能分开。通俗的理解就是原本需要一个人干的事,现在分给n个人干,各自干各自的,最终取得和一个人干的效果一样。
稍微正规一点的定义就是:一个业务分拆多个子业务,部署在不同的服务器上。 然后通过一定的通信协议,能够让这些子业务之间相互通信。
既然分给了n个人,那就涉及到这些人的沟通交流协作问题。想要去解决这些问题,就需要先聊聊分布式系统中的CAP理论。千万不要被这个看起来高大上的概念迷惑住。
二、简单的概述一下CAP理论指的是一个分布式系统最多只能同时满足一致性(Consistency)、可用性(Availability)和分区容错性(Partition tolerance)这三项中的两项。
1、一个小例子首先我们看一张图。
现在网络中有两个节点N1和N2,他们之间网络可以连通,N1中有一个应用程序A ...
Nginx(一)-快速入门
Nginx(一)-快速入门基本概念Nginx (“engine x”) 是一个高性能的 HTTP 和反向代理服务器,特点是占有内存少,并发能力强,事实上 nginx 的并发能力确实在同类型的网页服务器中表现较好
中国大陆使用 nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等
什么是nginx,做什么事情Nginx 可以作为静态页面的 web 服务器,同时还支持 CGI 协议的动态语言,比如 perl、 php等。但是不支持 java。 Java 程序只能通过与 tomcat 配合完成。 Nginx 专为性能优化而开发,性能是其最重要的考量,实现上非常注重效率 ,能经受高负载的考验,有报告表明能支持高达 50,000 个并发连接数。 nginx支持热部署,启动容易,可以做到不间断运行
正向代理用作正向代理来进行上网等功能。正向代理:如果把局域网外的 Internet 想象成一个巨大的资源库,则局域网中的客户端要访问 Internet,则需要通过代理服务器来访问,这种代理服务就称为正向代理。 国内访问不了谷歌.
反向代理反向代理,其实客户端对代理是无感知的,因为客户端不 ...
MyBatis(二)-增删改查
MyBatis(二)-增删改查环境搭建
创建 maven 工程
导入坐标
编写必要代码(实体类和持久层接口)
编写 SqlMapConfig.xml
编写映射配置文件
编写测试类
用户映射文件配置
那些过于基础的…什么方法名要对应还是不浪费时间了…
resultType 属性:用于指定结果集的类型
parameterType 属性:
用于指定传入参数的类型,传入的是一个类的对象 就写类的全名称。
sql 语句中使用#{}字符:它代表占位符, 相当于原来 jdbc 部分所学的?,都是用于执行语句时替换实际的数据。具体的数据是由#{}里面的内容决定的。
#{}中内容的写法:如果数据类型是基本类型,所以此处可以随意写。一般还是使用方法接收的参数名
如果是一个 User 对象,此处要写 User 对象中的属性名称。它用的是 ognl 表达式。
ognl 表达式:它是 apache 提供的一种表达式语言, 全称是:Object Graphic Navigation Language 对象图导航语言它是按照一定的语法格式来获取数据的。语法格式就是使用 #{对象.对象} ...
MyBatis(一)-框架概述与基础案例
MyBatis 框架概述 mybatis是一个优秀的基于 java 的持久层框架,它内部封装了 jdbc,使开发者只需要关注 sql语句本身, 而不需要花费精力去处理加载驱动、创建连接、创建 statement 等繁杂的过程。
mybatis通过xml 或注解的方式将要执行的各种statement配置起来,并通过java对象和statement 中 sql 的动态参数进行映射生成最终执行的 sql 语句,最后由 mybatis 框架执行 sql 并将结果映射为 java 对象并 返回。
采用 ORM (Object Relational Mapping 对象关系映射,就是把数据库表和实体类以及实体类的属性对应起来)思想解决了实体和数据库映射的问题,对 jdbc进行了封装,屏蔽了 jdbc api 底层访问细节,使我 们不用与 jdbc api 打交道,就可以完成对数据库的持久化操作。
Jdbc 问题分析1、数据库链接创建、释放频繁造成系统资源浪费从而影响系统性能,如果使用数据库链接池可解决此问题。
2、Sql 语句在代码 ...
Linux账号和磁盘管理
账号管理
简介
Linux系统是一个多用户多任务的分时操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。
用户的账号一方面可以帮助系统管理员对使用系统的用户进行跟踪,并控制他们对系统资源的访问;另一方面也可以帮助用户组织文件,并为用户提供安全性保护。
每个用户账号都拥有一个唯一的用户名和各自的口令。
用户在登录时键入正确的用户名和口令后,就能够进入系统和自己的主目录。
实现用户账号的管理,要完成的工作主要有如下几个方面:
用户账号的添加、删除与修改。
用户口令的管理。
用户组的管理。
用户账号的管理
用户账号的管理工作主要涉及到用户账号的添加、修改和删除。
添加用户账号就是在系统中创建一个新账号,然后为新账号分配用户号、用户组、主目录和登录Shell等资源。
添加账号 useradd
1useradd 选项 用户名
参数说明:
选项 :
-c comment 指定一段注释性描述。
-d 目录 指定用户主目录,如果此目录不存在,则同时使用-m选项,可以创建主目录。
-g 用户组 指定用户所属的用户组。
-G 用 ...
Linux基础命令+Vim
Linux简介Unix操作系统 多用户 多任务 支持多线程 多cpu的开源,免费,安全,高效,稳定的操作系统
处理高并发强悍
很多企业级的项目都部署到Linux/unix服务器运行
能运行主要的UNIX工具软件 应用程序和网络协议 Linux继承了Unix以网络为核心的思想
Kali linux:安全渗透测试使用
服务器都是使用命令行的
Linux和Unix的关系
Linux和Windows整理
Linux应用领域个人桌面应用服务器领域linux在服务器领域是最强的
嵌入式领域安装
之前好奇自己装过各种linux双系统 包括manjaro,deepin等,最终各种由于出现的网络过慢,换了镜像也没有效果问题删除了)以后再把一些教程同步过来 这里暂时只使用虚拟机
虚拟机使用vmware挺方便的 有兴趣的还可以装mac
在vmware 虚拟机上安装centOS 安装操作系统和软件是一样的
linux磁盘分区的时候需要注意分区名
使用xshell ,xftp 在官网可以使用个人免费版
网络链接
桥连接。 Linux可以和其它的系统通信。但是可能造成ip冲突
NAT:网络地址转换方式: ...
Docker
常用命令直接跳至”Docker的常用命令”
查询常用命令直接跳至”Docker的常用命令”
配置阿里云镜像:
yum-config-manager –add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
前面章节为官方文档翻译 后面为常用操作和自启设置
Docker是什么?系统平滑移植,容器虚拟化技术
Docker 是一个开源项目,诞生于 2013 年初,最初是 dotCloud 公司内部的一个业余项目。它基于 Google 公司推出的 Go 语言实现。 项目后来加入了 Linux 基金会,遵从了 Apache 2.0 协议,项目代码在 GitHub 上进行维护。
Docker 自开源后受到广泛的关注和讨论,以至于 dotCloud 公司后来都改名为 Docker Inc。Redhat 已经在其 RHEL6.5 中集中支持 Docker;Google 也在其 PaaS 产品中广泛应用。
Docker 项目的目标是实现轻量级的操作系统虚拟化解决方案。 Docker 的基础是 Linux 容器( ...
MySQL高级(二)--性能分析和优化
性能分析MySQL Query Optimizer
MySQL中有专门负责优化SELECT语句的优化器模块,主要功能: 通过计算分析系统中收集到的统计信息,为客户端请求的Query提供他认为最优的执行计划(他认为最优的数据检索方式,但不见得是DBA认为是最优的,这部分最耗费时间)
当客户端项MySQL请求一条Query,命令解析器模块完成请求分类,区别出是SELECT并转发给MySQL Query Optimizer时,MySQL Query Optimizer首先会对整条Query进行优化,处理掉一些常量表达式的预算,直接换算成常量值.并对Query中的查询条件进行简化和转换,如去掉一些无用或显而易见的条件,结构调整等,然后分析Query中的Hint信息(如果有),看显示Hint信息是否可以完全确定该Query的执行计划.如果没有Hint或Hint信息还不足以完全确定执行计划,则会读取所涉及对象的统计信息,根据Query进行相应的计算分析再得出最后的执行计划.
MySQL常见瓶颈
CPU: CPU在饱和的时候一般发生在数据装入内存或从磁盘上读取数据时候
IO: 磁盘I/O瓶颈发生在 ...
MySQL高级(一)--索引
MySQL高级(一)–索引
mysql基础部分增删改那些笔记当时全做在 marginNote思维导图上 现在反而觉得不方便了 … 以后再看看要不要搬过来
高级部分内容挺多的 为了提高 阅读效果 把以前偷懒截得图 大量手动码出来…
linux下安装目录
路径
解释
备注
/var/lib/mysql/
mysql数据库文件的存放路径
/var/lib/mysql/atguigu.cloud.pid
/usr/share/mysql
配置文件目录
mysql.server命令及配置文件
/usr/bin
相关命令目录
mysqladmin mysqldump等命令
/etc/init.d/mysql
启停相关脚本
修改默认的配置文件5.5 版本 :/usr/share/mysql/my-huge.cnf /etc/my.cnf
mysql的默认 字符集编码1234567891011121314151617181920212223#1. 查看字符集show variables like 'character%';show varia ...