JDK构造方法摘要 HashMap() 构造一个具有默认初始容量 (16) 和默认加载因子 (0.75) 的空 HashMap。...HashMap(int initialCapacity) 造一个带指定初始容量和默认加载因子 (0.75) 的空 HashMap。...一、概念 HashMap 的实例有两个参数影响其性能:初始容量和加载因子。容量是哈希表中桶的数量,初始容量只是哈希表在创建时的容量。加载因子是哈希表在其容量自动增加之前可以达到多满的一种尺度。...在设置初始容量时应该考虑到映射中所需的条目数及其加载因子,以便最大限度地减少 rehash 操作次数。如果初始容量大于最大条目数除以加载因子,则不会发生 rehash 操作。...二、举例 像HashMap,默认大小是16,也就是支持存储最多20个键值对,如果不超过20个键值对,可以不设置,如果超出,按如下公式计算后设置: initialCapacity = (需要存储的元素(键值对
本文由杨青同学投稿,总结了他在近期工作中对线程池容量设置的一点经验。...原文发于微信公众号:Java线程池容量设置 创建线程池的方式 Java中可以通过Executors和ThreadPoolExecutor的方式创建线程池,通过Executors可以快速创建四种常见的线程池...图1 选自infoQ文章聊聊并发(三) 具体讲解可以参考清英在infoQ发布的文章:http://www.infoq.com/cn/articles/java-threadPool 线程池容量设置 线程池的...corePoolSize设置是整个线程池中最关键的参数,设置太小会导致线程池的吞吐量不足,因为新提交的任务需要排队或者被handler处理掉(取决于拒绝策略);设置太大可能会耗尽计算机的CPU和内存资源...当线程池设置过大时: ? 图2 压测时把线程池参数设置得很大 当线程池设置较为合理时: ?
MySQL作为一款面向企业的数据库产品,必须具有能够处理高峰活动和数据容量增长的能力。...在进行容量规划时,架构师需要考虑因为用户的活动和数据增长所导致的资源使用变化,并需要考虑未来的促销活动或者其他预计的繁忙时期。...在MySQL容量规划的过程中,非常关键的一点是监视表的容量。 InnoDB的行和索引数据都保存在磁盘页中,页的默认大小为16KB。InnoDB表和索引由包含数据的叶页和包含页指针的非叶页组成。...例如, mysql> SELECT FILE_NAME,TOTAL_EXTENTS * EXTENT_SIZE as `size` -> FROM INFORMATION_SCHEMA.FILES ->...表的逻辑大小和物理大小,为制定基线,容量规划提供可测量的数值。
容量管理: 1、数据库大小估计 一种可靠的方式是 使用解压后的备份文件(必须是Xtrabackup的物理备份)来估算当前数据库的体积。...设置expire_logs_days非常重要,这样您就可以正确估算大小。 3、其它文件大小估计 3.1 MySQL在大的查询过程中,可能会产生巨量临时表。...容量预测 根据数据库的历史监控数据(zabbix 或 prometheus) ,我们可以大致预测数据文件的周增长量、binlog的周增长量 以及系统负载波动的趋势。...容量解决之道 1、历史数据归档 根据业务场景,按照时间归档,迁移历史数据到大容量廉价低速的磁盘。降低生产环境数据库体积和负载,较小的表体积,便于数据库备份和DDL操作。...http://www.jebriggs.com/blog/2010/07/mysql-storage-capacity-planning/
那么HashMap如何保证其容量一定可以是2^n呢? HashMap在两个可能改变其容量的地方都做了兼容处理: 1. 指定容量初始化值时; 2....其目的对于一个数字的二进制,从第一个不为0的位开始,把后面的所有位都设置成1。...总之,HashMap根据用户传入的初始化容量,利用无符号右移和按位或运算等方式计算出第一个大于该数的2的幂。 扩容 除了初始化的时候会指定HashMap的容量,在进行扩容的时候,其容量也可能会改变。...loadFactor是装载因子,表示HashMap满的程度,默认值为0.75f,设置成0.75有一个好处,那就是0.75正好是3/4,而capacity又是2的幂。 所以,两个数的乘积都是整数。...所以,通过保证初始化容量均为2的幂,并且扩容时也是扩容到之前容量的2倍,所以,保证了HashMap的容量永远都是2的幂。
应如何设置HashMap容量的初始值?...注意负载因子(即 loader factor)默认 为 0.75,如果暂时无法确定初始值大小,请设置为 16(即默认值)。...反例: HashMap 需要放置 1024 个元素,由于没有设置容量初始大小,随着元素增加而被迫不断扩容, resize()方法总共会调用 8 次,反复重建哈希表和数据迁移。...从上面信息可以知道几个知识点: HashMap默认的初始化容量是16,也就是不指定的情况,就是16 规范里建议我们设置 initialCapacity = (需要存储的元素个数 / 负载因子) + 1...1111和其它二进制数据进行与运算,顺便计算,没有发现相同的数据 找其它非1111…的数据进行与计算,发现,里面都要3个数据是1001,所以这种情况就会出现hash冲突 ok,归纳一下,设置为
前言 这个系列属于个人学习网易云课堂MySQL数据库工程师微专业的相关课程过程中的笔记,本篇为其“MySQL业务优化与设计”中的MySQL数据类型相关笔记。...正文 性能容量评估 分析线上业务场景 评估数据库服务器所需性能指标 预估可能成为瓶颈的服务器资源 帮助数据库性能调优 数据库服务器硬件性能指标 磁盘IO性能 内存容量...CPU 网络吞吐量 磁盘容量 数据库业务特点关键词 OLTP/OLAP类型 并发请求 读写比例 数据量 冷热数据比 数据分级存储 OLTP与OLAP T = Transaction 面向广大用户,高并发...多写场景相关资源:磁盘IO 数据量-总量 数据库服务器存储设备可扩容能力上限 根据估算的业务量,写入模式,分析数据增长量 预估一个硬件升级周期内数据库可存放数据的总量,上线时要留好余量 数据总量相关资源:磁盘容量...=127.0.0.1 --mysql-port=3306 --mysql-user=sys --mysql-password=netease --mysql-db=sbtest --max-requests
查看一个数据中所有表的相关信息: (1)可以在命令下使用show table status \G命令查看: (2)如果想知道MySQL数据库中每个表占用的空间、表记录的行数的话,可以打开MySQL的 information_schema...TABLE_SCHEMA : 数据库名 TABLE_NAME:表名 ENGINE:所使用的存储引擎 TABLES_ROWS:记录数 DATA_LENGTH:数据大小 INDEX_LENGTH:索引大小 其他字段请参考MySQL...desc, index_length desc; 3.查看指定数据库容量大小 例:查看mysql库容量大小 select table_schema as '数据库', sum(table_rows)..., 2)) as '索引容量(MB)' from information_schema.tables where table_schema='mysql'; 4.查看指定数据库各表容量大小 例:查看mysql...where table_schema='mysql' order by data_length desc, index_length desc; 参考:https://www.cnblogs.com/
查看一个数据中所有表的相关信息: (1)可以在命令下使用show table status \G命令查看: (2)如果想知道MySQL数据库中每个表占用的空间、表记录的行数的话,可以打开MySQL的 information_schema...数据库名 TABLE_NAME:表名 ENGINE:所使用的存储引擎 TABLES_ROWS:记录数 DATA_LENGTH:数据大小 INDEX_LENGTH:索引大小 其他字段请参考MySQL...desc, index_length desc; 3.查看指定数据库容量大小 例:查看mysql库容量大小 select table_schema as '数据库', sum(table_rows)..., 2)) as '索引容量(MB)' from information_schema.tables where table_schema='mysql'; 4.查看指定数据库各表容量大小 例:查看mysql...where table_schema='mysql' order by data_length desc, index_length desc; 参考:https://www.cnblogs.com/
背景 在开发过程中,设置 IDEA 连接数据mysql数据库连接时遇到异常“Server returns invalid timezone....意思是时区设置的不对。 于是寻找解决方法。 2.思路 先登录到mysql 安装所在的机器。...看下当前的mysql时区设置 show variables like "%time_zone%"; 下图显示 SYSTEM,表示用的默认时区,我们要修改成 +8的北京所在时区。 ?...示例 Step 1: 登录到mysql 安装所在的机器 执行指令:mysql -hlocalhost -uroot -p,回车 输入密码 即进入mysql交互模式 Step 2: 修改时区 set...设置重启永久生效 修改配置文件 /etc/my.cnf [mysqld] default-time_zone = '+8:00' 重启mysql systemctl stop mysqld.service
mysql> show variables like 'collation_%'; mysql> show variables like 'character_set_%'; 缺省是latin1编码...修改库的编码: mysql> alter database db_name character set utf8; 修改表的编码: mysql> ALTER TABLE table_name CONVERT...TO CHARACTER SET utf8 COLLATE utf8_general_ci; 可以在mysql中设置编码,单个设置 mysql> set character_set_connection...=utf8; mysql> set character_set_database=utf8; mysql> set character_set_results=utf8; mysql> set character_set_server...mysqld] default-character-set=utf8 character_set_server=utf8 init_connect='SET NAMES utf8' 重启mysql
MySQL默认字符编码的设置 MySQL的默认编码是Latin1,不支持中文,那么如何修改MySQL的默认编码呢,下面以UTF-8为例来说明 需要注意的是,要修改的地方非常多,相应的修改方法也很多...下面是一种最简单最彻底的方法: 一、Windows 1、中止MySQL服务 2、在MySQL的安装目录下找到my.ini,如果没有就把my-medium.ini复制为一个my.ini...即可 3、打开my.ini以后,在[client]和[mysqld]下面均加上default-character-set=utf8,保存并关闭 4、启动MySQL服务 二、Linux... 1、中止MySQL服务(bin/mysqladmin -u root shutdown) 2、在/etc/下找到my.cnf,如果没有就把MySQL的安装目录下的support-files...服务(bin/mysqld_safe &) 非常简单,这样的修改一劳永逸,今后MySQL一切相关的默认编码均为UTF-8了,创建新表格的时候无需再次设置 需要注意的是,当前数据库中已经存在的数据仍保留现有的编码方式
但是,要注意的是,max_binlog_size参数设置的是单个binlog文件的最大大小,而不是所有binlog文件的总容量。...SET GLOBAL max_binlog_size = 1073741824; -- 设置单个binlog文件的最大大小为1GB 或在MySQL配置文件(例如my.cnf或my.ini)中添加或修改以下行...SET GLOBAL expire_logs_days = 7; -- 设置binlog文件的保留天数为7天 或在MySQL配置文件(例如my.cnf或my.ini)中添加或修改以下行: [mysqld...] expire_logs_days = 7 -- 设置binlog文件的保留天数为7天 应用配置: 如果您在MySQL配置文件中修改了这些参数,需要重启MySQL服务器以使新的配置生效。...sudo systemctl restart mysql 请注意,更改这些参数可能会影响您的备份策略和复制设置,所以在进行更改之前,请确保您了解了这些参数的影响,并在非生产环境中测试了新的配置。
在性能测试中,需要根据具体的性能需求和系统架构等情况,采用不同的测试策略,其中最常见的策略就有容量测试。这篇文章,就来聊聊容量测试以及容量规划的一些内容。。。 一、什么是容量?如何理解?...1、容量定义 所谓容量,即系统处于最大负载状态或某项指标达到所能接受的最大阈值下对请求的最大处理能力。...2、如何理解 ①、系统的容量(处理能力)是有限的; ②、容量是可度量的; 二、如何统计容量指标?...三、容量测试 容量测试是性能测试里的一种测试方法,它的目的就是测量系统的最大容量,为系统扩容,性能优化提供参考,节省成本投入,提高资源利用率。...,一般吞吐量和IO是比较关注的指标; 四、容量规划 1、为什么需要容量规划?
1.授予远程主机访问MySQL 在MySQL Server端,执行mysql 命令进入mysql 命令模式。使用grant命令用来建立新用户,指定用户口令并增加用户权限。...需要通过-h指定MySQL服务端的主机地址。 示例二: 授予来自任意远程主机的用户dablelv对MySQL服务端的所有数据库和数据表拥有所有权限。...MySQL用户权限的列表。...@localhost; 查询结果如下: image.png 查看MySQL所有用户的权限,可以从mysql的用户表mysql.user中查询。...select * from mysql.user where user="userName"; ---- 参考文献 [1]MySQL用户权限类型 [2]查看MYSQL数据库中所有用户及拥有权限
一、常见现象 运维工作中会经常维护MySQL主从服务器,当然Slave我们只是用于读操作。一般权限开通也只授权只读账号,但是有时候维护工作可能不是一个人在做,你不能保证其他同事都按照这个标准操作。...有同事可能会授权Slave库MySQL账号为all或者select,update,insert,delete。...为了避免上述问题,我们需要给MySQL的Slave设置为只读模式。...read_only=0 为取消普通账号的只读模式 授权普通MySQL测试账号 mysql> grant select,insert,update,delete on s18.* to 'test'@...可以用锁表: mysql> flush tables with read lock; Query OK, 0 rows affected (0.18 sec) 使用root账号测试: mysql> delete
设置规则 这个其实与validate_password_policy的值有关,默认为1,所以刚开始设置的密码必须符合长度,且必须含有数字,小写或大写字母,特殊字符。...如果我们不希望密码设置的那么复杂,需要修改两个全局参数:validate_password_length默认值为8,最小值为4 set global validate_password_policy=0...password oldpass "newpass" 更改当前用户密码 ALTER USER USER() IDENTIFIED BY '123456'; 用UPDATE直接编辑user表 use mysql...newpass') WHERE user = 'root'; FLUSH PRIVILEGES; root密码丢失 关闭验证密码 mysqld_safe --skip-grant-tables& 登陆 mysql...-u root mysql 重置 UPDATE user SET password=PASSWORD("new password") WHERE user='root'; 5.7版本 UPDATE user
可以在application.yml添加配置项: spring: datasource: driver-class-name: com.mysql.jdbc.Driver # 使用开发用数据库...book_dev url: jdbc:mysql://192.168.99.100:32770/my_blog?
前言 这里我已经将MySQL的数据库编码设置为UTF-8,所以下面现实的都是UTF-8。 ...设置MySQL数据库的编码方式有三种,分别是基于session会话的、基于全局gloable的、永久性改变的。...正文 1.首先连接到MySQL : mysql -uroot -proot 2.输入\s,即可查看数据库的字符编码 3.查看数据库的详细编码 输入:show variables like '%char...6.设置全局的数据库字符编码,即使基于整个MySQL服务的,当重启MySQL服务的时候,编码依然会变为原来的字符编码 set global character_set_database=gbk; ...但是我们重启MySQL数据库的时候,编码又是回复为原来的utf-8了。
文章目录 1.授予远程主机访问MySQL 2.MySQL用户的权限类型 3.查看用户权限 参考文献 1.授予远程主机访问MySQL 在 MySQL Server 端,执行 mysql 命令进入 mysql...需要通过-h指定MySQL服务端的主机地址。 示例二: 授予来自任意远程主机的用户dablelv对MySQL服务端的所有数据库和数据表拥有所有权限。...MySQL用户权限的列表。...; 查询结果如下: 查看 MySQL 所有用户的权限,可以从用户表 mysql.user 中查询。...select * from mysql.user where user="userName"; ---- 参考文献 MySQL用户权限类型 查看MYSQL数据库中所有用户及拥有权限
领取专属 10元无门槛券
手把手带您无忧上云