mirror of
https://github.com/immich-app/immich.git
synced 2025-01-21 00:52:43 -05:00
1a3d05ffc3
* chore: remove UPLOAD_LOCATION as it isn't used in the server * docker: remove network in docker compose as docker creates one by default * nginx: update reverse proxy to put web at root and api at /api * docker: remove unneeded exposed ports and docker network Align dev setup with prod, but with ports exposed for direct connection Most communication between services happens on the internal network, so we don't need to expose all these services. With the nginx changes, the api and web panel are both server through the reverse proxy on / for web and /api for the API. The only service that should expose ports is nginx as that is the entrypoint to the application. * chore: remove CORS now we serve the api on /api in the default setup * docs: update README.md to include /api * Fixed docket-compose file for dev environment and websocket on web and mobile Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
260 lines
10 KiB
Markdown
260 lines
10 KiB
Markdown
<p align="center">
|
|
<a href="https://opensource.org/licenses/MIT"><img src="https://img.shields.io/badge/license-MIT-green.svg?color=3F51B5&style=for-the-badge&label=License&logoColor=000000&labelColor=ececec" alt="License: MIT"></a>
|
|
<a href="https://github.com/alextran1502/immich"><img src="https://img.shields.io/github/stars/alextran1502/immich.svg?style=for-the-badge&logo=github&color=3F51B5&label=Stars&logoColor=000000&labelColor=ececec" alt="Star on Github"></a>
|
|
<a href="https://immichci.little-home.net/viewType.html?buildTypeId=Immich_BuildAndroidAndGetArtifact&guest=1">
|
|
<img src="https://img.shields.io/teamcity/http/immichci.little-home.net/s/Immich_BuildAndroidAndGetArtifact.svg?style=for-the-badge&label=Android&logo=teamcity&logoColor=000000&labelColor=ececec" alt="Android Build"/>
|
|
</a>
|
|
<a href="https://immichci.little-home.net/viewType.html?buildTypeId=Immich_BuildAndPublishIOSToTestFlight&guest=1">
|
|
<img src="https://img.shields.io/teamcity/http/immichci.little-home.net/s/Immich_BuildAndPublishIOSToTestFlight.svg?style=for-the-badge&label=iOS&logo=teamcity&logoColor=000000&labelColor=ececec" alt="iOS Build"/>
|
|
</a>
|
|
<a href="https://actions-badge.atrox.dev/alextran1502/immich/goto?ref=main">
|
|
<img alt="Build Status" src="https://img.shields.io/endpoint.svg?url=https%3A%2F%2Factions-badge.atrox.dev%2Falextran1502%2Fimmich%2Fbadge%3Fref%3Dmain&style=for-the-badge&label=Github Action&logo=github&labelColor=ececec&logoColor=000000" />
|
|
</a>
|
|
<a href="https://discord.gg/rxnyVTXGbM">
|
|
<img src="https://img.shields.io/discord/979116623879368755.svg?label=Immich%20Discord&logo=Discord&style=for-the-badge&logoColor=000000&labelColor=ececec" atl="Immich Discord"/>
|
|
</a>
|
|
<br/>
|
|
<br/>
|
|
<br/>
|
|
<br/>
|
|
|
|
<p align="center">
|
|
<img src="design/feature-panel.png" title="Immich Logo">
|
|
</p>
|
|
</p>
|
|
|
|
# Immich
|
|
|
|
**High performance self-hosted photo and video backup solution.**
|
|
|
|
![](https://media.giphy.com/media/y8ZeaAigGmNvlSoKhU/giphy.gif)
|
|
|
|
Loading ~4000 images/videos
|
|
|
|
## Screenshots
|
|
|
|
### Mobile
|
|
<p align="left">
|
|
<img src="design/login-screen.png" width="150" title="Login With Custom URL">
|
|
<img src="design/backup-screen.png" width="150" title="Backup Setting Info">
|
|
<img src="design/selective-backup-screen.png" width="150" title="Backup Setting Info">
|
|
<img src="design/home-screen.jpeg" width="150" title="Home Screen">
|
|
<img src="design/search-screen.jpeg" width="150" title="Curated Search Info">
|
|
<img src="design/shared-albums.png" width="150" title="Shared Albums">
|
|
<img src="design/nsc6.png" width="150" title="EXIF Info">
|
|
</p>
|
|
|
|
### Web
|
|
<p align="left">
|
|
<img src="design/web-home.jpeg" width="49%" title="Home Dashboard">
|
|
<img src="design/web-detail.jpeg" width="49%" title="Detail">
|
|
</p>
|
|
|
|
# Note
|
|
|
|
**!! NOT READY FOR PRODUCTION! DO NOT USE TO STORE YOUR ASSETS !!**
|
|
|
|
This project is under heavy development, there will be continuous functions, features and api changes.
|
|
|
|
# Features
|
|
|
|
| | Mobile | Web |
|
|
| - | - | - |
|
|
| Upload and view videos and photos | Yes | Yes
|
|
| Auto backup when app is opened | Yes | N/A
|
|
| Selective album(s) for backup | Yes | N/A
|
|
| Download photos and videos to local device | Yes | Yes
|
|
| Multi-user support | Yes | Yes
|
|
| Shared Albums | Yes | No
|
|
| Quick navigation with draggable scrollbar | Yes | Yes
|
|
| Support RAW (HEIC, HEIF, DNG, Apple ProRaw) | Yes | Yes
|
|
| Metadata view (EXIF, map) | Yes | Yes
|
|
| Search by metadata, objects and image tags | Yes | No
|
|
| Administrative functions (user management) | No | Yes
|
|
|
|
|
|
# System Requirement
|
|
|
|
**OS**: Preferred unix-based operating system (Ubuntu, Debian, MacOS...etc).
|
|
|
|
I haven't tested with `Docker for Windows` as well as `WSL` on Windows
|
|
|
|
*Raspberry Pi can be used but `microservices` container has to be comment out in `docker-compose` since TensorFlow has not been supported in Docker image on arm64v7 yet.*
|
|
|
|
**RAM**: At least 2GB, preffered 4GB.
|
|
|
|
**Core**: At least 2 cores, preffered 4 cores.
|
|
|
|
# Getting Started
|
|
|
|
You can use docker compose for development and testing out the application, there are several services that compose Immich:
|
|
|
|
1. **NestJs** - Backend of the application
|
|
2. **SvelteKit** - Web frontend of the application
|
|
3. **PostgreSQL** - Main database of the application
|
|
4. **Redis** - For sharing websocket instance between docker instances and background tasks message queue.
|
|
5. **Nginx** - Load balancing and optimized file uploading.
|
|
6. **TensorFlow** - Object Detection (COCO SSD) and Image Classification (ImageNet).
|
|
|
|
## Step 1: Populate .env file
|
|
|
|
Navigate to `docker` directory and run
|
|
|
|
```
|
|
cp .env.example .env
|
|
```
|
|
|
|
Then populate the value in there.
|
|
|
|
Notice that if set `ENABLE_MAPBOX` to `true`, you will have to provide `MAPBOX_KEY` for the server to run.
|
|
|
|
Pay attention to the key `UPLOAD_LOCATION`, this directory must exist and is owned by the user that run the `docker-compose` command below.
|
|
|
|
**Example**
|
|
|
|
```bash
|
|
###################################################################################
|
|
# Database
|
|
###################################################################################
|
|
DB_USERNAME=postgres
|
|
DB_PASSWORD=postgres
|
|
DB_DATABASE_NAME=immich
|
|
|
|
###################################################################################
|
|
# Upload File Config
|
|
###################################################################################
|
|
UPLOAD_LOCATION=<put-the-path-of-the-upload-folder-here>
|
|
|
|
###################################################################################
|
|
# JWT SECRET
|
|
###################################################################################
|
|
JWT_SECRET=randomstringthatissolongandpowerfulthatnoonecanguess
|
|
|
|
###################################################################################
|
|
# MAPBOX
|
|
####################################################################################
|
|
# ENABLE_MAPBOX is either true of false -> if true, you have to provide MAPBOX_KEY
|
|
ENABLE_MAPBOX=false
|
|
MAPBOX_KEY=
|
|
|
|
###################################################################################
|
|
# WEB
|
|
###################################################################################
|
|
# This is the URL of your vm/server where you host Immich, so that the web frontend
|
|
# know where can it make the request to.
|
|
# For example: If your server IP address is 10.1.11.50, the environment variable will
|
|
# be VITE_SERVER_ENDPOINT=http://10.1.11.50:2283/api
|
|
VITE_SERVER_ENDPOINT=http://192.168.1.216:2283/api
|
|
```
|
|
|
|
## Step 2: Start the server
|
|
|
|
To **start**, run
|
|
|
|
```bash
|
|
docker-compose -f ./docker/docker-compose.yml up
|
|
```
|
|
|
|
If you have a few thousand photos/videos, I suggest running docker-compose with *scaling* option for the `immich_server` container to handle high I/O load when using fast scrolling.
|
|
|
|
```bash
|
|
docker-compose -f ./docker/docker-compose.yml up --scale immich-server=5
|
|
```
|
|
|
|
To *update* docker-compose with newest image (if you have started the docker-compose previously)
|
|
|
|
```bash
|
|
docker-compose -f ./docker/docker-compose.yml pull && docker-compose -f ./docker/docker-compose.yml up
|
|
```
|
|
|
|
The server will be running at `http://your-ip:2283/api` through `Nginx`
|
|
|
|
## Step 3: Register User
|
|
|
|
Access the web interface at `http://your-ip:2283` to register an admin account.
|
|
|
|
<p align="left">
|
|
<img src="design/admin-registration-form.png" width="300" title="Admin Registration">
|
|
<p/>
|
|
|
|
Additional accounts on the server can be created by the admin account.
|
|
|
|
<p align="left">
|
|
<img src="design/admin-interface.png" width="500" title="Admin User Management">
|
|
<p/>
|
|
|
|
## Step 4: Run mobile app
|
|
|
|
The app is distributed on several platforms below.
|
|
|
|
## F-Droid
|
|
You can get the app on F-droid by clicking the image below.
|
|
|
|
[<img src="https://fdroid.gitlab.io/artwork/badge/get-it-on.png"
|
|
alt="Get it on F-Droid"
|
|
height="80">](https://f-droid.org/packages/app.alextran.immich)
|
|
|
|
|
|
## Android
|
|
|
|
#### Get the app on Google Play Store [here](https://play.google.com/store/apps/details?id=app.alextran.immich)
|
|
|
|
*The App version might be lagging behind the latest release due to the review process.*
|
|
|
|
<p align="left">
|
|
<img src="design/google-play-qr-code.png" width="200" title="Google Play Store">
|
|
<p/>
|
|
|
|
## iOS
|
|
|
|
#### Get the app on Apple AppStore [here](https://apps.apple.com/us/app/immich/id1613945652):
|
|
|
|
*The App version might be lagging behind the latest release due to the review process.*
|
|
|
|
|
|
<p align="left">
|
|
<img src="design/ios-qr-code.png" width="200" title="Apple App Store">
|
|
<p/>
|
|
|
|
|
|
# Development
|
|
|
|
The development environment can be started from the root of the project after populating the `.env` file with the command:
|
|
|
|
```bash
|
|
make dev # required Makefile installed on the system.
|
|
```
|
|
|
|
All servers and web container are hot reload for quick feedback loop.
|
|
|
|
# Support
|
|
|
|
If you like the app, find it helpful, and want to support me to offset the cost of publishing to AppStores, you can sponsor the project with [**Github Sponsor**](https://github.com/sponsors/alextran1502), or a one time donation with the Buy Me a coffee link below.
|
|
|
|
[!["Buy Me A Coffee"](https://www.buymeacoffee.com/assets/img/custom_images/orange_img.png)](https://www.buymeacoffee.com/altran1502)
|
|
|
|
This is also a meaningful way to give me motivation and encouragement to continue working on the app.
|
|
|
|
Cheers! 🎉
|
|
|
|
# Known Issue
|
|
|
|
## TensorFlow Build Issue
|
|
|
|
*This is a known issue on RaspberryPi 4 arm64-v7 and incorrect Promox setup*
|
|
|
|
TensorFlow doesn't run with older CPU architecture, it requires a CPU with AVX and AVX2 instruction set. If you encounter the error `illegal instruction core dump` when running the docker-compose command above, check for your CPU flags with the command and make sure you see `AVX` and `AVX2`:
|
|
|
|
```bash
|
|
more /proc/cpuinfo | grep flags
|
|
```
|
|
|
|
If you are running virtualization in Promox, the VM doesn't have the flag enabled.
|
|
|
|
You need to change the CPU type from `kvm64` to `host` under VMs hardware tab.
|
|
|
|
`Hardware > Processors > Edit > Advanced > Type (dropdown menu) > host`
|
|
|
|
Otherwise you can:
|
|
- edit `docker-compose.yml` file and comment the whole `immich-machine-learning` service **which will disable machine learning features like object detection and image classification**
|
|
- switch to a different VM/desktop with different architecture.
|