I create a support post for my question here : https://discord.com/channels/564160730845151244/564160731327758347/1113760474341838868
"Is it a way to have function on same docker network than appwrite / mariadb / redis / influxdb / others docker services ? To avoid hosts mapping (or network hit)"
To be able to connect redis via redis://redis, to call appwrite sdk with http://appwrite/v1 (and not domain name), etc. => Use docker network
Is this on a self-hosted Appwrite instance, Or on Appwrite cloud?
Self hosted
Then you have two options to achieve that. I'll write you in detail in couple of minutes
Appwrite docker compose utilize three networks (docker network is like a virtual switch)
- gateway - The default and not in use
- appwrite - Composed all of appwrite services and the
executor
- the container that runs the runtimes. - runtimes - An isolated network between the
executor
and any dynamiclly created runtimes. Like in the picture
The reason for that is to be able to isolated a - could-be-risky - code from the server.
So if you do want your function to share to access the main network you can either add the runtimes
network to any service in your docker-compose.yml
file that you want to be accessible from the functions one, for example to redis
and mariadb
mariadb:
image: mariadb:10.7 # fix issues when upgrading using: mysql_upgrade -u root -p
container_name: appwrite-mariadb
<<: *x-logging
restart: unless-stopped
networks:
- appwrite
- runtimes
volumes:
- appwrite-mariadb:/var/lib/mysql:rw
environment:
- MYSQL_ROOT_PASSWORD=${_APP_DB_ROOT_PASS}
- MYSQL_DATABASE=${_APP_DB_SCHEMA}
- MYSQL_USER=${_APP_DB_USER}
- MYSQL_PASSWORD=${_APP_DB_PASS}
command: 'mysqld --innodb-flush-method=fsync'
redis:
image: redis:7.0.4-alpine
container_name: appwrite-redis
<<: *x-logging
restart: unless-stopped
command: >
redis-server
--maxmemory 512mb
--maxmemory-policy allkeys-lru
--maxmemory-samples 5
networks:
- appwrite
- runtimes
volumes:
- appwrite-redis:/data:rw
Or you can edit the .env
file and set the value of OPEN_RUNTIMES_NETWORK
to:
OPEN_RUNTIMES_NETWORK=appwrite_appwrite
And then all the function will be added to the main network.
After any change let docker reload the infrastructure by running
docker compose up -d
Oh don't understand that runtimes is internal network for function. i trie with "appwrite" network while appwrite-executor already on appwrite network It's works, ty 🙂
[SOLVED] Function on same network than docker services
Recommended threads
- Realtime with multiple connections
I need the Realtime on multiple Collections for diffrent applicational logic. So my question is: Is there a way to have only 1 Websocket connection or do I need...
- Can't login or deploy functions in Appwr...
Hello, since i updatet to the appwrite cli 6.1.0 i can't login or deploy functions with the cli. When i call the command: "appwrite get account --verbose" i ge...
- Create admin user?
I'm not really sure how this is supposed to work, I installed Appwrite through docker-compose and set it up. When I launched the app and went into it, I created...