-
Notifications
You must be signed in to change notification settings - Fork 15
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
11 changed files
with
73 additions
and
39 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,33 +1,33 @@ | ||
# Orthweb - Orthanc Solution on AWS | ||
<a href="https://www.orthanc-server.com/"><img style="float" align="right" src="assets/images/orthanc_logo.png"></a> | ||
<a href="https://www.orthanc-server.com/"><img style="float" align="right" src="assets/images/orthanc_logo.png" width="200"></a> | ||
|
||
|
||
[data:image/s3,"s3://crabby-images/4366a/4366a6f744d1340fa0241d98c1ea549294785590" alt="Linux"](https://aws.amazon.com/amazon-linux-2) | ||
[data:image/s3,"s3://crabby-images/85f63/85f633f001c75cf326788af621c4d7ebffa2cdee" alt="Docker"](https://www.docker.com/) | ||
[data:image/s3,"s3://crabby-images/9912d/9912de450ac363a6f902500f5136c758d2d2d915" alt="Postgres"](https://www.postgresql.org/) | ||
[data:image/s3,"s3://crabby-images/69028/6902868ae26b4c924e65b715aa343567aa64ccfe" alt="Nginx"](https://nginx.org/en/index.html) | ||
data:image/s3,"s3://crabby-images/9e4a8/9e4a8f83f92d905a0f0215482c341faba0b432fb" alt="Keycloak" | ||
[data:image/s3,"s3://crabby-images/9e4a8/9e4a8f83f92d905a0f0215482c341faba0b432fb" alt="Keycloak"](https://www.keycloak.org/) | ||
[data:image/s3,"s3://crabby-images/47103/47103218e826062811f43d5aa1db3a3a48856060" alt="License"](https://opensource.org/licenses/Apache-2.0) | ||
|
||
[data:image/s3,"s3://crabby-images/7eb38/7eb38af073c40f3cfef78d7274d1bfc2ff61639b" alt="Terraform"](https://www.terraform.io/) | ||
[data:image/s3,"s3://crabby-images/d272f/d272f4b61bc509107523ac69c54160957205fdfe" alt="Amazon EC2"](https://aws.amazon.com/ec2/) | ||
[data:image/s3,"s3://crabby-images/7b0b7/7b0b7ce71b6f7ddb9af4156a61757a30b70a23d2" alt="Amazon S3"](https://aws.amazon.com/s3/) | ||
[data:image/s3,"s3://crabby-images/f8874/f8874edbe95e4181deb5dd366ca0aa32a4ad0de9" alt="Amazon RDS"](https://aws.amazon.com/rds/postgresql/) | ||
|
||
[data:image/s3,"s3://crabby-images/47103/47103218e826062811f43d5aa1db3a3a48856060" alt="License"](https://opensource.org/licenses/Apache-2.0) | ||
[data:image/s3,"s3://crabby-images/db4ce/db4ce7fb1e5a8baa8034301086c0e7eb93db27ed" alt="Latest Release"](https://github.com/digihunch/orthweb/releases/latest) | ||
|
||
## Overview | ||
|
||
The **[Orthweb](https://github.com/digihunch/orthweb)** project helps imaging IT staff build an **[Orthanc](https://www.orthanc-server.com/)** solution on AWS. The project addresses the cloud foundation and configuration management to host the Orthanc application. Follow to the [documentation](https://digihunch.github.io/orthweb/) for instructions and architecture discussions. 💪 Let's automate medical imaging! | ||
|
||
Orthanc handles sensitive data and must operate on a secure cloud platform. Typically, large organizations can afford specialized IT resources to build enterprise-scale cloud foundations. This cloud foundation is known as a [landing zone](https://www.digihunch.com/2022/12/landing-zone-in-aws/). Each department in the organization is allocated with a segment of the landing zone (e.g. an VPC), to deploys their own applications. | ||
Imaging systems like Orthanc handle sensitive data and must operate on secure cloud platforms. Typically, large organizations dedicate specialized IT resources to build enterprise-scale cloud foundations. This cloud foundation is known as a [landing zone](https://www.digihunch.com/2022/12/landing-zone-in-aws/). In the landing zone, each business line of the organization is allocated with a segment (e.g. an VPC), to deploy their own applications. | ||
|
||
In reality, many Orthanc users are small entities (e.g. startups, research groups, independent clinics, etc) without an overarching cloud strategy. They need a secure and scalable cloud foundation to leverage Orthanc. To close this gap, we propose a cloud-based Orthanc solution to address the cloud foundation and configuration management, and [created](https://www.digihunch.com/2020/11/medical-imaging-web-server-deployment-pipeline/) the **Orthweb** project. | ||
In reality, many Orthanc users are small teams without overarching cloud strategies from their parent organizations. They are startups, research departments, independent clinics, and so on. They need equally secure and scalable cloud foundations to leverage Orthanc. To close this gap, we propose a cloud-based Orthanc solution to address the cloud foundation and configuration management, and [created](https://www.digihunch.com/2020/11/medical-imaging-web-server-deployment-pipeline/) the **Orthweb** project to implement it. | ||
|
||
<img align="middle" src="assets/images/Overview.png"> | ||
<br/><br/> | ||
data:image/s3,"s3://crabby-images/7f2b1/7f2b1628cf8c72913bac6d458b8c563d1e8e9545" alt="Diagram" | ||
|
||
For cloud foundation, **Orthweb** project uses **Terraform** template (an infrastructure-as-code technology) to provision a self-contained infrastrcture stack in a single AWS account, without relying upon established network infrastructure. The infrastructure layer provisioned in this project contains a single VPC with multiple subnets, along with useful VPC endpoints. The infrastructure layer also contains encryption keys, managed database service and S3 storage. The infrastrcture footprint is small but secure, aiming to comply with regulatory requirements such as HIPPA. However, regulatory auditing is the responsibility of the Orthanc adopter. | ||
|
||
For cloud foundation, **Orthweb** project uses **Terraform** template (an infrastructure-as-code technology) provisions its own self-contained infrastrcture stack in a single AWS account. It does not rely upon an established network infrastructure platform. The network infrastructure layer provisioned in this project contains a single VPC with multiple subnets, along with required endpoints. The infrastructure layer also contains encryption keys, managed database service and S3 storage. The infrastrcture footprint is small but secure. It aims to comply with regulatory requirements such as HIPPA. However, regulatory auditing is the responsibility of the Orthanc adopter. For configuration management, **Orthweb** leverages cloud-init [user data](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/user-data.html) and `makefile` to configure the servers upon initialization. The artifact to install **Orthanc** is stored in the [orthanc-config](https://github.com/digihunchinc/orthanc-config) repository. | ||
In addition to cloud resource provisioning, the **Orthweb** project also streamles the installation and configuration of Orthanc solution, by proposing a paradign for Orthanc configuration management. The project leverages cloud-init [user data](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/user-data.html) and `makefile` to configure the servers during the initialization process at the end of cloud resource provisioning. The artifact to install **Orthanc** is stored in the [orthanc-config](https://github.com/digihunchinc/orthanc-config) repository, for users to fork and customize. | ||
<br/><br/> | ||
|
||
The project architecture also takes into account other operational aspects, such as high availability, resiliency and automation in the configuration of **Orthanc** application with Docker, using the official [Orthanc image](https://hub.docker.com/r/orthancteam/orthanc). For those considering hosting Orthanc on Kubernetes, check out our sister project [Korthweb](https://github.com/digihunch/korthweb). | ||
The project uses the official [Orthanc image](https://hub.docker.com/r/orthancteam/orthanc) and orchestrate the application containers with Docker daemon on EC2 instances. For those considering hosting Orthanc on Kubernetes, check out our sister project [Korthweb](https://github.com/digihunch/korthweb). |
Oops, something went wrong.