Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fscm/docker-mongodb
Docker recipe to build an MongoDB image
https://github.com/fscm/docker-mongodb
docker docker-image dockerfile mongodb
Last synced: 4 days ago
JSON representation
Docker recipe to build an MongoDB image
- Host: GitHub
- URL: https://github.com/fscm/docker-mongodb
- Owner: fscm
- License: mit
- Created: 2019-02-25T16:09:32.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2022-01-03T15:58:54.000Z (almost 3 years ago)
- Last Synced: 2024-11-07T16:23:40.176Z (about 2 months ago)
- Topics: docker, docker-image, dockerfile, mongodb
- Language: Dockerfile
- Size: 35.2 KB
- Stars: 1
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.build.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# MongoDB for Docker
Docker image with MongoDB.
## Synopsis
This script will create a Docker image with MongoDB installed and with all
of the required initialization scripts.The Docker image resulting from this script should be the one used to
instantiate a MongoDB server.## Getting Started
There are a couple of things needed for the script to work.
### Prerequisites
Docker, either the Community Edition (CE) or Enterprise Edition (EE), needs to
be installed on your local computer.#### Docker
Docker installation instructions can be found
[here](https://docs.docker.com/install/).### Usage
In order to create a Docker image using this Dockerfile you need to run the
`docker` command with a few options.```shell
docker image build --force-rm --no-cache --quiet --tag /:
```- `` - *[required]* The user that will own the container image (e.g.: "johndoe").
- `` - *[required]* The container name (e.g.: "mongodb").
- `` - *[required]* The container tag (e.g.: "latest").
- `` - *[required]* The location of the Dockerfile folder.A build example:
```shell
docker image build --force-rm --no-cache --quiet --tag johndoe/my_mongodb:latest .
```To clean any _`none`_ image(s) left by the build process the following
command can be used:```shell
docker image rm `docker image ls --filter "dangling=true" --quiet`
```You can also use the following command to achieve the same result:
```shell
docker image prune -f
```### Instantiate a Container
In order to end up with a functional MongoDB service - after having build
the container - some configurations have to be performed.To help perform those configurations a small set of commands is included on the
Docker container.- `help` - Usage help.
- `init` - Configure the MongoDB service (__Not required in this image__).
- `start` - Start the MongoDB service.To store the data of the MongoDB server a volume should be created and added
to the container when running the same.#### Creating Volumes
To be able to make all of the MongoDB data persistent, the same will have to
be stored on a different volume.Creating volumes can be done using the `docker` tool. To create a volume use
the following command:```shell
docker volume create --name
```Two create the required volume the following command can be used:
```shell
docker volume create --name my_mongodb
```**Note:** A local folder can also be used instead of a volume. Use the path of
the folder in place of the volume name.#### Configuring the MongoDB Server
This step is not required for this MongoDB Docker image.
#### Start the MongoDB Server
After configuring the MongoDB server the same can now be started.
Starting the MongoDB server can be done with the `start` command.
```shell
docker container run --volume :/data:rw --detach --publish 27017:27017 /: start
```To help managing the container and the MongoDB instance a name can be given
to the container. To do this use the `--name ` docker option when
starting the serverAn example on how the MongoDB service can be started:
```shell
docker container run --volume my_mongodb:/data/mongodb:rw --detach --publish 27017:27017 --name my_mongodb johndoe/my_mongodb:latest start
```To see the output of the container that was started use the following command:
```shell
docker container attach
```Use the `ctrl+p` `ctrl+q` command sequence to detach from the container.
#### Stop the MongoDB Server
If needed the MongoDB server can be stoped and later started again (as long as
the command used to perform the initial start was as indicated before).To stop the server use the following command:
```shell
docker container stop
```To start the server again use the following command:
```shell
docker container start
```### MongoDB Status
The MongoDB server status can be check by looking at the MongoDB server output
data using the docker command:```shell
docker container logs
```### Add Tags to the Docker Image
Additional tags can be added to the image using the following command:
```shell
docker image tag /:
```### Push the image to Docker Hub
After adding an image to Docker, that image can be pushed to a Docker registry... Like Docker Hub.
Make sure that you are logged in to the service.
```shell
docker login
```When logged in, an image can be pushed using the following command:
```shell
docker image push /:
```Extra tags can also be pushed.
```shell
docker image push /:
```## Contributing
1. Fork it!
2. Create your feature branch: `git checkout -b my-new-feature`
3. Commit your changes: `git commit -am 'Add some feature'`
4. Push to the branch: `git push origin my-new-feature`
5. Submit a pull requestPlease read the [CONTRIBUTING.md](CONTRIBUTING.md) file for more details on how
to contribute to this project.## Versioning
This project uses [SemVer](http://semver.org/) for versioning. For the versions
available, see the [tags on this repository](https://github.com/fscm/docker-mongodb/tags).## Authors
- **Frederico Martins** - [fscm](https://github.com/fscm)
See also the list of [contributors](https://github.com/fscm/docker-mongodb/contributors)
who participated in this project.## License
This project is licensed under the MIT License - see the [LICENSE](LICENSE)
file for details