-
-
Notifications
You must be signed in to change notification settings - Fork 399
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Update Docker-compose file #1071
base: main
Are you sure you want to change the base?
Changes from all commits
d97d813
5f50970
3b6c691
6ddd886
d601262
1709b02
dc1aade
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,27 +1,40 @@ | ||
version: '2' | ||
version: '3.8' | ||
|
||
services: | ||
postgres: | ||
image: postgres:9.5-alpine | ||
image: postgres:15-alpine | ||
hostname: stringer-postgres | ||
restart: always | ||
networks: | ||
- stringer | ||
volumes: | ||
- ~/stringer:/var/lib/postgresql/data | ||
- ~/stringer/postgres:/var/lib/postgresql/data | ||
environment: | ||
- POSTGRES_PASSWORD=super_secret_password | ||
- POSTGRES_PASSWORD=<PLEASE_ENTER_YOUR_PASSWORD> | ||
- POSTGRES_USER=db_user | ||
- POSTGRES_DB=stringer | ||
|
||
web: | ||
image: mockdeep/stringer | ||
image: mockdeep/stringer:latest | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. these images should actually move to |
||
build: . | ||
depends_on: | ||
- postgres | ||
restart: always | ||
ports: | ||
- 80:8080 | ||
- '8080:8080' | ||
networks: | ||
- stringer-network | ||
environment: | ||
- SECRET_KEY_BASE=<your configuration> | ||
- ENCRYPTION_PRIMARY_KEY<your configuration> | ||
- ENCRYPTION_DETERMINISTIC_KEY=<your configuration> | ||
- ENCRYPTION_KEY_DERIVATION_SALT=<your configuration> | ||
# - FETCH_FEEDS_CRON="*/5 * * * *" # optional | ||
# - CLEANUP_CRON="0 0 * * *" # optional | ||
- PORT=8080 | ||
- DATABASE_URL=postgres://db_user:super_secret_password@postgres:5432/stringer | ||
- DATABASE_URL=postgres://db_user:<PLEASE_ENTER_YOUR_PASSWORD>@stringer-postgres:5432/stringer | ||
|
||
networks: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Do you think you could separate out some of these changes into different PRs? I think it would be helpful to discuss them independently so that I can get a better understanding of what each of them is doing. I'm sure some of them would be easy to merge, but others seem like they might cause more problems for our users and I'd like to think about them more. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Hey no problem, I can separate into :
If you validate this I will do it during the week ! There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. That sounds reasonable. I think the network updates might be a good 4th PR, too. |
||
stringer: | ||
external: false | ||
name: stringer |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,29 +2,30 @@ | |
|
||
## Production ready setup using docker-compose | ||
|
||
Download [docker-compose.yml](../docker-compose.yml) and in the corresponding folder, run `docker-compose up -d`, give it a second and visit `localhost` | ||
Download [docker-compose.yml](../docker-compose.yml) and in the corresponding folder, run `docker-compose up -d`, give it a second and visit `localhost:8080` | ||
|
||
## Production ready manual setup | ||
|
||
The following steps can be used to setup Stringer on Docker, using a Postgres database also running on Docker. | ||
|
||
1. Setup a Docker network so the two containers we're going to create can communicate: | ||
|
||
```Sh | ||
docker network create --driver bridge stringer | ||
``` | ||
```Sh | ||
docker network create --driver bridge stringer | ||
``` | ||
|
||
2. Setup a Postgres Docker container: | ||
|
||
```Sh | ||
docker run --detach \ | ||
--name stringer-postgres \ | ||
--restart always \ | ||
--volume /srv/stringer/data:/var/lib/postgresql/data \ | ||
--volume ~/stringer:/var/lib/postgresql/data \ | ||
--net stringer \ | ||
-e POSTGRES_PASSWORD=myPassword \ | ||
-e POSTGRES_PASSWORD=<PLEASE_ENTER_YOUR_PASSWORD> \ | ||
-e POSTGRES_USER=db_user \ | ||
-e POSTGRES_DB=stringer \ | ||
postgres:9.5-alpine | ||
postgres:12-alpine | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. How come you chose version There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I had an issues with postgres 9 which update all my folder permissions. Apparently it was fixed in 12 version, and it's the first version with the fix. May be you can use 15 version, but I haven't try it. I could do some test if you want ! There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @Ni-g-3l sure, that would be helpful! I'm running 15.3 with my instance. It's not a huge deal, though, we can always upgrade more later. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I just upgraded my instance, let's pass this week and see what will happen. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I see. I wonder if upgrading to 12 will cause issues for upgrading users, too. I guess we can leave it at 12 for now and see how things go. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think this is more because of an upgrade of postgres using the same data directory, rather than a problem with postgres 15 itself. So updating from 9 to 12 is already going to give issues, I think we may as well do 15. I think this is probably where a stringer export comes in - we could export the data, upgrade to a newer version of postgres, and then re-import. imo, we should set this to 15. If a new user comes to stringer, they'll want the latest version of postgres; if a previous user is updating, they should know that they need to back up their system and that changing postgres versions incurs problems. We may want to announce this in some way in the next release though, as a PSA. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. (also, fwiw, someone else I know from the FOSS community created this repo that auto-upgrades postgres without issues like this, and then runs the container as postgres normally would. But it's an additional layer of complexity, and I imagine postgres will eventually coalesce things into their docker image) There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Hmm, I'm not sure what the best approach here is. I'm imagining the upgrade process would be smoother if it was more gradual, but that seems like a pretty lengthy process. That repo you linked could be really handy to smooth that process.
I unfortunately haven't figured out a good release process yet. Maybe we need to set up a changelog and tagging somehow. It's a little weird, though, since we aren't releasing a gem or the like. |
||
``` | ||
|
||
3. Run the Stringer Docker image: | ||
|
@@ -35,15 +36,15 @@ docker run --detach \ | |
--net stringer \ | ||
--restart always \ | ||
-e PORT=8080 \ | ||
-e DATABASE_URL=postgres://postgres:myPassword@stringer-postgres/stringer \ | ||
-e DATABASE_URL=postgres://db_user:<PLEASE_ENTER_YOUR_PASSWORD>@stringer-postgres/stringer \ | ||
-e SECRET_KEY_BASE=$(openssl rand -hex 64) \ | ||
-e ENCRYPTION_PRIMARY_KEY=$(openssl rand -hex 64) \ | ||
-e ENCRYPTION_DETERMINISTIC_KEY=$(openssl rand -hex 64) \ | ||
-e ENCRYPTION_KEY_DERIVATION_SALT=$(openssl rand -hex 64) \ | ||
-e FETCH_FEEDS_CRON="*/5 * * * *" \ # optional | ||
-e CLEANUP_CRON="0 0 * * *" \ # optional | ||
-p 127.0.0.1:8080:8080 \ | ||
stringer-rss/stringer | ||
-p 8080:8080 \ | ||
mockdeep/stringer:latest | ||
``` | ||
|
||
That's it! You now have a fully working Stringer instance up and running! | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Personally I don't care too much for changes like these since the password will need to be changed anyway. If we want to make it so that the container won't launch without a password change then we should probably just not set this value
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm fine with cosmetic changes, and this seems like maybe an improvement. If there's a way to force the user to input it, though, so that they can't miss it, that seems even better.