草庐IT

docker-mysql

全部标签

DBA面试题:MySQL缓存池LRU算法做了哪些改进?

下图是MySQL(MySQL5.7版本)体系架构图:MySQL的InnoDbBufferPool缓冲池是主内存中的一个区域,用来缓存InnoDB在访问表和索引时的数据。对于频繁使用的数据可以直接从内存中访问,从而加快处理速度。如果一台服务器专用作MySQL数据库使用时,通常将70%~80%(具体看总内存大小而定)的物理内存空间分配给缓冲池。缓冲池由多个缓冲池实例(innodb_buffer_pool_instances)组成,每个实例都有自己的锁和数据结构,这样可以在多线程环境中提高并发性能。缓冲池中的页可以分为干净页和脏页,干净页是指与磁盘上的数据一致的页,而脏页则是指已经被修改但尚未写回磁

解惑MySQL:对int(1)与int(10)的认知误区

困惑最近遇到个问题,有个表的要加个user_id字段,user_id字段可能很大,于是我提mysql工单altertablexxxADDuser_idint(1),领导看到我的sql工单说:这int(1)怕是不够用吧,接下来是一通解释。其实这不是我第一次遇到这样的问题了,其中不乏有工作5年以上的老司机。包括我经常也看到同事一直使用int(10),感觉用了int(1),字段的上限就被限制,真实情况肯定不是这样。数据说话我们知道在mysql中int占4个字节,那么对于无符号的int,最大值是2^32-1=4294967295,将近40亿,难道用了int(1),就不能达到这个最大值吗?CREATET

深入MySQL优化:提升数据库性能的关键策略

MySQL优化从设计上,可根据需要:分库分表、读写分离、冷热分离、使用缓存、定期进行数据清理。从客户端使用上,使用连接池、避免大事务、返回数据多使用物理分页。从优化MySQL配置文件上,调整MySQL配置文件中的参数,如缓冲区大小、最大连接数等,以适应应用程序的需要。从优化表结构上,使用合适的存储引擎;避免使用大型或不必要的列,并尽可能使用小型数据类型;尽量把字段设置为NOTNULL;对于某些文本字段来说,例如“省份”或者“性别”,我们可以将他们定义为ENUM(枚举)类型。因为在MySQL中,ENUM类型被当做数值型数据来处理,而数值型数据被处理起来的速度要比文本类型要快得多。从优化查询上,善

MySQL 是如何保证 binlog 和 redo log同时提交的?

MYSQL一个事务在提交的时候能够保证binlog和redolog是同时提交的,并且能在宕机恢复后保持binlog和redolog的一致性。先来看看什么是redolog和binlog,以及为什么要保持它们的一致性。什么是redolog,binlogredolog是innodb引擎层产生的日志,MYSQL从磁盘读取数据的单位是一页,当修改页中某条数据时,该行所在的数据页就变成了脏页,由于脏页并不会立马刷新到磁盘,所以redolog会记录下数据页进行了哪些变动,用于服务崩溃时的数据恢复。redolog是固定大小的,由多个文件组成一个环形的结构。图片redolog由两个指针,writepos和che

springBoot分布式 + jdk17 部署到docker

本地springBoot打包成jar包,上传到服务器上,再当前目录新建DockerfileFROMopenjdk:17-jdk-alpineCOPY*.jar/app.jarCMDecho"======dockertest======"EXPOSE8081ENTRYPOINT["java","-jar","/app.jar"]进入当前目录执行:dockerbuild-tset-day-backend-1.0.0.nsapshot.生成新的镜像,再执行dockerrun-d-p8888:8888--nameset-day-backendset-day-backend-1.0.3.nsapshot

6.零基础快速入门Python Web开发——docker+uwsgi部署

单容器部署+uwsgi2.1案例1)把UWSGI加入Django容器中的准备工作在前面例子中我们使用了Django了自带的runserver命令启动了测试服务器,但实际生成环境中你应该需要使用支持高并发的uwsgi服务器来启动Django服务。尽管本节标题是把uwsgi加入到Django容器中,但本身这句话就是错的,因为我们Django的容器是根据django_docker_img:v1这个镜像生成的,我们的镜像里并没有包含uwsgi相关内容,只是把uwsgi.ini配置文件拷入到Django容器是不会工作的。所以这里我们需要构建新的Dockerfile并构建新的镜像和容器。为了方便演示,我们

Docker之自定义镜像上传阿里云

目录一、Alpine制作jdk镜像1.下载镜像2.创建并编辑Dockerfile3.执行Dockerfile构建镜像4.测试二、Alpine制作jre镜像 1.下载jre2.上传gz压缩包,删除无用的文件,并重新压缩3.创建并编辑Dockerfile4.执行Dockerfile并构建镜像5.测试三、将镜像上传阿里云一、Alpine制作jdk镜像alpineLinux简介   1.AlpineLinux是一个轻型Linux发行版,它不同于通常的Linux发行版,Alpine采用了musllibc和     BusyBox以减少系统的体积和运行时的资源消耗。   2.AlpineLinux提供了自

Java高校学校校园社团报名管理系统设计与实现(Idea+Springboot+mysql)

 博主介绍:黄菊华老师《Vue.js入门与商城开发实战》《微信小程序商城开发》图书作者,CSDN博客专家,在线教育专家,CSDN钻石讲师;专注大学生毕业设计教育和辅导。所有项目都配有从入门到精通的基础知识视频课程,学习后应对毕业设计答辩。项目配有对应开发文档、开题报告、任务书、PPT、论文模版等项目都录了发布和功能操作演示视频;项目的界面和功能都可以定制,包安装运行!!!如果需要联系我,可以在CSDN网站查询黄菊华老师在文章末尾可以获取联系方式目的:本课题主要目标是设计并能够实现一个基于Java技术的校园社团管理系统,整个网站项目使用了B/S架构,基于Java的Springboot框架下开发;

docker常用命令[超详细]

目录docker命令dockerpsdockerpulldockerimagesdockerrundockerstartdockerrestartdockerinfodockerlogsdockerrmdockerrmidockerexecdockerstatsdockersavedockerloaddockerexportdockerimportdockerinspectdockercpdockervolumedockernetworkdockerbuliddockerexecdocker命令dockerpsdockerps命令用于列出当前正在运行的Docker容器。它的语法如下:docke

MySQL知识点总结(五)——锁

MySQL知识点总结(五)——锁锁分类表锁&行锁如何添加表锁?如何添加行锁?读锁&写锁行锁&间隙锁(gaplock)&临键锁(next-keylock)加锁机制分析可重复读隔离级别下的加锁机制唯一索引等值查询非唯一索引等值查询范围查询读已提交隔离级别下的加锁机制如何强行释放锁锁是每一个关系型数据库都肯定会有的一种处理并发读写冲突的机制。通过加锁,当前事务可以保证它加了锁的行记录,不被别的事务修改,保证了事务的隔离性。保证事务隔离性的机制,除了加锁以外,还有MVCC,那什么时候加锁,什么时候使用MVCC机制呢?在一个事务中,当我们的查询语句显式的加锁,也就是“select…lockinshare