mirror of
https://github.com/QYG2297248353/appstore-1panel.git
synced 2024-11-28 16:26:19 +08:00
85 lines
3.3 KiB
YAML
85 lines
3.3 KiB
YAML
version: "3.8"
|
|
|
|
networks:
|
|
${DOCKER_NET}:
|
|
external: true
|
|
|
|
services:
|
|
es-node:
|
|
container_name: ${CONTAINER_NAME}-${ES_NODE_NAME}
|
|
restart: always
|
|
image: docker.elastic.co/elasticsearch/elasticsearch:8.12.0
|
|
volumes:
|
|
- ${ES_ROOT_PATH}/certs:/usr/share/elasticsearch/config/certs
|
|
- ${ES_ROOT_PATH}/${ES_NODE_NAME}/data:/usr/share/elasticsearch/data
|
|
- ${ES_ROOT_PATH}/${ES_NODE_NAME}/logs:/usr/share/elasticsearch/logs
|
|
- ${ES_ROOT_PATH}/${ES_NODE_NAME}/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml
|
|
- ${ES_ROOT_PATH}/${ES_NODE_NAME}/plugins:/usr/share/elasticsearch/plugins
|
|
ports:
|
|
- "${PANEL_APP_PORT_HTTPS}:9200"
|
|
- "${ES_COMMUNICATION_PORT}:9300"
|
|
networks:
|
|
- ${CLUSTER_NETWORK}
|
|
command: >
|
|
bash -c '
|
|
echo "start es-node";
|
|
if [ ! -f config/certs/${ES_NODE_NAME}.zip ]; then
|
|
echo "Creating certs";
|
|
echo -ne \
|
|
"instances:\n"\
|
|
" - name: ${ES_NODE_NAME}\n"\
|
|
" dns:\n"\
|
|
" - ${ES_NODE_NAME}\n"\
|
|
" - localhost\n"\
|
|
" ip:\n"\
|
|
" - 127.0.0.1\n"\
|
|
> config/certs/${ES_NODE_NAME}.yml;
|
|
bin/elasticsearch-certutil cert --silent --pem -out config/certs/${ES_NODE_NAME}.zip --in config/certs/${ES_NODE_NAME}.yml --ca-cert config/certs/ca/ca.crt --ca-key config/certs/ca/ca.key;
|
|
unzip config/certs/${ES_NODE_NAME}.zip -d config/certs;
|
|
fi;
|
|
echo "Setting file permissions"
|
|
chown -R root:root config/certs;
|
|
exec /usr/local/bin/docker-entrypoint.sh elasticsearch
|
|
'
|
|
environment:
|
|
- node.name=${ES_NODE_NAME}
|
|
- cluster.name=${CLUSTER_NAME}
|
|
- cluster.initial_master_nodes=${ES_INITIAL_MASTER_NODES}
|
|
- discovery.seed_hosts=${ES_SEED_HOSTS}
|
|
- ELASTIC_PASSWORD=${ELASTIC_PASSWORD}
|
|
- bootstrap.memory_lock=true
|
|
- xpack.security.enabled=${ES_XPACK_SECURITY_ENABLED}
|
|
- xpack.security.http.ssl.enabled=${ES_XPACK_SECURITY_ENABLED}
|
|
- xpack.security.http.ssl.key=certs/${ES_NODE_NAME}/${ES_NODE_NAME}.key
|
|
- xpack.security.http.ssl.certificate=certs/${ES_NODE_NAME}/${ES_NODE_NAME}.crt
|
|
- xpack.security.http.ssl.certificate_authorities=certs/ca/ca.crt
|
|
- xpack.security.transport.ssl.enabled=${ES_XPACK_SECURITY_ENABLED}
|
|
- xpack.security.transport.ssl.key=certs/${ES_NODE_NAME}/${ES_NODE_NAME}.key
|
|
- xpack.security.transport.ssl.certificate=certs/${ES_NODE_NAME}/${ES_NODE_NAME}.crt
|
|
- xpack.security.transport.ssl.certificate_authorities=certs/ca/ca.crt
|
|
- xpack.security.transport.ssl.verification_mode=certificate
|
|
- xpack.license.self_generated.type=basic
|
|
- ES_JAVA_OPTS=-Xms${ES_JAVA_OPTS_XMS} -Xmx${ES_JAVA_OPTS_XMX}
|
|
mem_limit: ${MEM_LIMIT}
|
|
ulimits:
|
|
memlock:
|
|
soft: -1
|
|
hard: -1
|
|
nofile:
|
|
soft: 65536
|
|
hard: 65536
|
|
healthcheck:
|
|
test:
|
|
[
|
|
"CMD-SHELL",
|
|
"curl -s --cacert config/certs/ca/ca.crt https://localhost:9200 | grep -q 'missing authentication credentials'",
|
|
]
|
|
interval: 10s
|
|
timeout: 10s
|
|
retries: 120
|
|
logging:
|
|
driver: "json-file"
|
|
options:
|
|
max-size: "10m"
|
|
max-file: "3"
|