
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
- list() is very slow; eventually shows no...
When I use the web browser to view the collections in my database, the documents they contain are normally displayed within a few seconds. For a few days now, h...
- Can't start docker containers beacuse no...
Hi, I'm testing my app where I upload also files to appwrite storage. As I suspect, I've filled up my disk. Now I can't start Appwrite. Could I ask for help wit...
- Problems with adding my custom domain
