Heap堆内存理解
一个JVM实例只有一个堆内存,堆内存的大小是可以调节的。类加载器读取类文件后,需要把类文件、方法、常量放入到堆内存中,以便执行器执行,堆内存分为三部分:
1. Permanent Space 永久存储区
永久存储区是一个常驻内存区域,用于存放JDK自身所携带的Class,Interface的元数据,也就是说它存储的是运行环境必须的类信息,被装载进此区域的数据是不会被垃圾回收器回收掉的,关闭JVM才会释放此区域所占用的内存。
2.Young Generation Space 新生区
新生区是类的诞生、成长、消亡的区域,一个类在这里产生,应用,最后被垃圾回收器收集,结束生命。
新生区又分为两部分:伊甸区(Eden space)和幸存者区(Survivor pace)。
所有的类都是在伊甸区被new出来的。幸存区有两个: 0区(Survivor 0 space)和1区(Survivor 1 space)。当伊甸园的空间用完时,程序又需要创建对象,JVM的垃圾回收器将对伊甸园区进行垃圾回收,将伊甸园区中的不再被其他对象所引用的对象进行销毁。然后将伊甸园中的剩余对象移动到幸存0区。若幸存0区也满了,再对该区进行垃圾回收,然后移动到1区。那如果1区也满了呢?再移动到养老区。
3. Tenure Generation Space 养老区
养老区用于保存从新生区筛选出来的JAVA对象,一般池对象都在这个区域活跃。 三个区的示意图如下:
口水:第一次写博客,欢迎大家来拍砖。
最近项目中用mysql主从复制主要是为了实现读写分离、数据库备份、故障转移的需要,采用的是一主一从,配置比较简单。
自已在本机做测试
测试环境如下:
OS:win7
mysql: 安装两个版本的mysql ,一个是5.5.x(高版本做主) 一个是5.1.x.(从)
配置文件 win下my.ini linux下:my.conf
1. 配置主库
#配置主从数据库
server-id=1
#主从复制是通过二进制文件来进行,所以要开启日志功能
log-bin=mysql-bin
#主机,读写都可以
read-only=0
#需要备份数据,多个写多行
binlog-do-db=core
#不需要备份的数据库,多个写多行
binlog-ignore-db=test
binlog-ignore-db=mysql
2. 配置从库
#主从配置
server-id=2
log-bin=mysql-bin
#主机地址
master-host=127.0.0.1
master-user=slave1
master-password=slave1
master-port=3309
#如果从服务器发现主服务器断掉,重新连接的时间差(秒)
master-connect-retry=60
#只复制某个库
replicate-do-db=core
#不复制某个库
replicate-ignore-db=mysql
3. 设置权限
给主数据库授予一个可以进行复制的用户
GRANT replication slave ON *.* TO 'slave1'@'%' IDENTIFIED BY 'slave1';
4. 启动从库复制
mysql>slave start;
myslq>slave stop;
5. 查看复制状态
主库:mysql>show master status\G(注意,不用加分号)
从库:mysql>show slave status\G
从库设置主库信息
change master to
> master_host='master_ip',
> master_user='user',
> master_password='pwd',
> master_port=3307,
> master_log_file='mysql-bin.000020',
> master_log_pos=135617781;
6. 解决未同步的可能出现的问题
set GLOBAL SQL_SLAVE_SKIP_COUNTER=1
出现过的问题:
a. character 的问题 是mysql client的问题,需要把客户端的character设置和server 一样
7. 如果出现复制错误,从服务器的错误日志(HOSTNAME.err)中也会出现错误消息。
以上配置测试通过,有问题欢迎一起来讨论