【docker】docker启动neo4j,并配置内存

注意下:--volume=宿主机目录:/data--publish=宿主机port:7474 --publish=宿主机port:7687

bash 复制代码
docker run -d \
--publish=9801:7474 --publish=9802:7687 \
--env NEO4J_AUTH=neo4j/passwd \
--volume=/opt/docker/data/vol-data/neo4j4.2:/data \
--restart always \
--memory 2G
--name neo4j4.2 neo4j:4.2.9-community

查看容器占用内存

bash 复制代码
docker stats neo4j4.2
# CONTAINER ID   NAME       CPU %     MEM USAGE / LIMIT   MEM %     NET I/O         BLOCK I/O         PIDS
# a3dbc78b8ac2   neo4j4.2   0.34%     395.8MiB / 2GiB     19.33%    738kB / 605kB   80.6MB / 5.77MB   47
bash 复制代码
docker exec -it neo4j4.2 /bin/bash
cd /var/lib/neo4j/conf

cat neo4j.conf

可以看到neo4j的配置文件 neo4j.conf,默认#dbms.memory.heap.initial_size=512m #dbms.memory.heap.max_size=512m 都没有配置。而dbms.memory.pagecache.size=512M已配置

bash 复制代码
# 启动java-heap内存,建议启动和最大设置成一样的。
# Java Heap Size: by default the Java heap size is dynamically calculated based
# on available system resources. Uncomment these lines to set specific initial
# and maximum heap size.
#dbms.memory.heap.initial_size=512m
#dbms.memory.heap.max_size=512m

# neo4j索引从文件系统映射内存。设置内存大小。
# The amount of memory to use for mapping the store files.
# The default page cache memory assumes the machine is dedicated to running
# Neo4j, and is heuristically set to 50% of RAM minus the Java heap size.
#dbms.memory.pagecache.size=10g

# 全局事务内存。所有事务的总内存
# Limit the amount of memory that all of the running transaction can consume.
# By default there is no limit.
#dbms.memory.transaction.global_max_size=256m

# 单个事务的内存。
# Limit the amount of memory that a single transaction can consume.
# By default there is no limit.
#dbms.memory.transaction.max_size=16m

docker 配置文档
neo4j配置官网

修改配置:

bash 复制代码
# 复制到宿主机
 docker cp neo4j4.2:/var/lib/neo4j/conf/neo4j.conf .

# 内容 vim neo4j.conf :
dbms.memory.heap.initial_size=512m
dbms.memory.heap.max_size=512m
dbms.memory.transaction.global_max_size=512m
dbms.memory.pagecache.size=1024M

# 复制回去
docker cp ./neo4j.conf neo4j4.2:/var/lib/neo4j/conf
# check一下
docker exec neo4j4.2 cat /var/lib/neo4j/conf/neo4j.conf | grep memory
# 重启容器
docker restart neo4j4.2

参考文章

如何为 docker 容器设置内存限制?

相关推荐
Johny_Zhao4 小时前
Docker + CentOS 部署 Zookeeper 集群 + Kubernetes Operator 自动化运维方案
linux·网络安全·docker·信息安全·zookeeper·kubernetes·云计算·系统运维
zwjapple5 小时前
docker-compose一键部署全栈项目。springboot后端,react前端
前端·spring boot·docker
代码老y7 小时前
Docker:容器化技术的基石与实践指南
运维·docker·容器
DuelCode7 小时前
Windows VMWare Centos Docker部署Springboot 应用实现文件上传返回文件http链接
java·spring boot·mysql·nginx·docker·centos·mybatis
杨浦老苏12 小时前
开源服务运行监控工具Lunalytics
docker·群晖·网站监控
呆萌的代Ma18 小时前
解决Mac上的老版本docker desktop 无法启动/启动后一直转圈/无法登陆账号的问题
macos·docker·eureka
feilieren18 小时前
Docker 安装 Elasticsearch 9
运维·elasticsearch·docker·es
KaiwuDB19 小时前
使用Docker实现KWDB数据库的快速部署与配置
数据库·docker
cleble20 小时前
(转)使用DockerCompose部署微服务
docker
朱杰jjj1 天前
Docker容器中无法使用vim、vi命令处理
docker·容器·vim