This is what we do in the implementation phase:
|2||Set up a domain name system (DNS).|
|3||Set up an SMTP server.|
|4||Set up an NTP server.|
|4||Set up a connection to the customer's data center.|
|6||Set up the environments (e.g., Development, Test, Pre-Production, and Production).|
|7||Implement monitoring and alerting.|
|9||Implement backup and disaster recovery.|
|10||Manage users and permissions.|
|11||Manage environments and artifacts.|
|12||Manage logs and backups.|
|13||Manage upgrades and migrations.|
|Hand over the production environment to the customer.|
Set up remote access to the customer's instance
|Table of Contents|
Remote access to Amazon EC2
WSO2 does all the Managed Cloud deployments in an Amazon Virtual Private Cloud (Amazon VPC). A VPC enables you to launch Amazon Web Services (AWS) into a virtual network that you define. A VPC improves the security of your data by providing network-level control and isolation for the AWS. This virtual network closely resembles a traditional network but with improved security, reliability, and scalability.
The customers peer their VPC(s) within the WSO2-managed VPC, which is an extension of the WSO2 corporate network as shown in the diagram below:
This setup allows WSO2 Cloud Ops to access the customer's Production and non-production VPCs. This connectivity is built up on top of an IPSec VPN tunnel and a VPC peer interface that are managed by the AWS.
The customer is to provide the following:
- VPC ID to peer (Production and non-production VPC IDs)
- The AWS account ID
After the customer gets a VPC peer request from WSO2 and it is approved by the customer, WSO2 implements the rest of the solution within a single day. Audit logs for remote logins are stored in Amazon S3 for auditing purposes.
Set up a domain name system (DNS)
The Domain Name System (DNS) is a server that translates domain names, which are alphanumeric and can be easily remembered by humans, to numerical IP addresses that are recognized by the Internet. The DNS is the Internet's primary directory service that determines which physical server a request should be routed to, when a visitor calls a domain name over the Internet.
For the servers in the customer's data center to connect to the virtual machines in the Amazon VPC, we need the domain-name-to-IP mappings set up in a DNS server. Customers can either use their own DNS servers for this, or allow WSO2 to use the Amazon Route53 service as depicted in the diagrams below. If the customer doesn't use Amazon Route53 services, s/he is to share the DNS name mappings for the IP addresses provided by WSO2.
- The DNS in the VPC: WSO2 uses an Amazon Route53 instance to maintain the domain-name-to-IP mappings related to the Managed Cloud.
- The DNS in the customer's data center: WSO2 provides the domain-name-to-IP mappings related to the Managed Cloud to the customer, who manages the DNS server in the customer's data center.
Set up an SMTP server
SMTP is shortened for Simple Mail Transfer Protocol, which is an Internet standard for email transmission. An SMTP server is a computer running SMTP, and which delivers email messages to their corresponding recipients.
The customers can either use their own SMTP servers or allow WSO2 to use Amazon SES. If the customer does not use Amazon SES, s/he is to share the SMTP credentials of the customer's email server.
Shown below is how an SMTP server in the customer's data center communicates with the WSO2 EC2 instance in the Amazon VPC:
Diagram: SMTP server communicates with the WSO2 EC2 instance
Set up an NTP server
NTP is shorted for Network Time Protocol, which is a networking protocol for synchronizing time over a network. Shown below is how the NTP server in the customer's data center communicates, over NTP, with the WSO2 virtual machines in the Amazon VPC. The customer is to share the NTP server details with WSO2 and ensure that the virtual machines where the WSO2 products are running on can reach the NTP server through the customer's firewall.
Diagram: NTP server communicates with the WSO2 EC2 instance
Set up a connection to the customer's data center
If the customer wants to connect his/her private AWS network with the data center that is managed by WSO2, the following options are available.
The customer ensures ingress and egress traffic through the firewall between the customer's data center and WSO2 Managed Cloud. WSO2 shares the product ports through which WSO2 products communicate with the data center services.
- Set up a direct connection to the customer's data center from the AWS. An Internet Service Provider (ISP) must be available.
Set up a connection using an Internet Protocol Security (IPsec ) VPN. The data center managed by WSO2 needs to have hardware supported by AWS. Also, the customer must provide the following:
- An Internet-routable IP address for the customer's gateway's external interface.
- A BGP Autonomous System Number (ASN), if the customer needs dynamic routing.
- IP prefixes in Classless Inter-Domain Routing (CIDR) to advertise to the VPC if the customer uses static routing.
- The hardware vendor, model and the software version of the router.
Set up the environments
The WSO2 Managed Cloud offering is for hosting and maintaining WSO2 products in an Amazon EC2 instance that the customer purchases. Here are the tasks performed by the WSO2 Managed Cloud team when setting up the environments. For additional services, the customer can purchase WSO2 Support.
|Tasks within the WSO2 Managed Cloud SLA||Tasks covered by WSO2 Support services|
|1||Set up an AWS account upon the customer's request (excluding the costs pertaining to the hosting services).|
Develop and deploy applications and services.
Set up the virtual machines and networking in the customer's AWS.
Execute IT management tasks (e.g., creating users).
Deploy the WSO2 products that the customer purchased, according to the deployment architecture that was created in the Planning phase.
Execute quality assurance on the system.
(WSO2 will outsource Vulnerability Assessment and Penetration tests t o third-party consultants.)
Create user accounts with admin privileges for the customer to log in to the Management Consoles of the WSO2 products.
Conduct trainings on WSO2 products.
|5||Guarantee the availability of the Managed Cloud (See Support and Maintenance).|
|6||Upgrade the WSO2 products and install software patches upon request. Security patches provided by the OS vendor are installed automatically.|
If the customer wants to synchronize his/her monitoring with that of WSO2, the operations teams from both sides need to agree on certain technical requirements such as additional agents that must be installed on hosts, how to expose dashboards to other networks, how to send alerts to additional email addresses and phones etc.
|Network and infrastructure-level security||As the Managed Cloud solutions are deployed in AWS, they inherit the security measures mentioned in https://aws.amazon.com/security/.|
|Operating system security|
Implement backup and disaster recovery
A disaster is a system failure that cannot be recovered using its own resources. WSO2 provides disaster recovery only upon the customer's request. If requested, WSO2 maintains the recovery scripts and backups in a geographically separate location, and in a different AWS region (DR site). In the event of a disaster, WSO2 sets up the system at the DR site using the backups and recovery scripts.
The backup and disaster recovery process is shown in the diagram below:
Diagram: The backup and disaster recovery process
Note the following regarding the backup and disaster recovery process:
- All backup processes are automated.
- Backups are taken of hosted artifacts such as web applications and services, application and system logs, and databases related to the solution, including WSO2 product databases.
- Backups are taken from the primary setup to the DR site daily, although this frequency can change depending on the size of the data and the rate that the data changes.
- The customer can request log and artifact backups for the last three months, anytime.
- WSO2 cannot provide database backups immediately upon the customer's request. This is because the database backups are stored in a way unique to the Amazon RDS, and it requires some time to be extracted properly.
- The following have to be determined after a drill (test run) of the recovery process:
- Recovery Point Objective (RPO): the point in time at which the system was last in a well-known state. This depends on the backup frequency.
- Recovery Time Objective (RTO): how much time will be taken to recover the system to the last well-known state.
- WSO2 stores all artifact and log backups in AWS and archives them to Amazon Glacier upon the customer's request.
- WSO2 takes database backups as Amazon RDS snapshots.
- If there are Elastic Block Storage (EBS) volumes in the deployment, WSO2 takes daily snapshots using the AWS-provided snapshot feature.
Manage users and permissions
- The WSO2 operations team will have accounts with admin privileges to the Linux servers and will provide read-only access to the customers upon request.
- If the customer creates and owns the AWS account:
- The customer must share multi-factor-authentication-enabled identity and access management (IAM) users with access to the AWS management console.
- The customer must share IAM users with sufficient privileges to invoke the AWS APIs and share the access and secret keys with WSO2.
- The IAM users should have admin privileges to the following services:
Manage environments and artifacts
Artifacts are resources such as scripts, patches, updates, and services that run on top of the WSO2 products.
- All non-production environments (e.g., Dev, Test, Pre-Prod, etc.) should be architecturally identical to the production environments.
- WSO2 can set up non-production environments, reset, and upgrade them upon the customer's request.
- In case of a migration or an upgrade, the customer and WSO2 account manager are to decide how to handle the migration of customer-specific data and any custom codes.
- WSO2 does not monitor and take backups of non-production environments. If there is an issue in a non-production environment, the customer is expected to open a hosting incident in the bug tracking system.
- The customer is responsible for storing, versioning, updating, removing, testing and verifying artifacts in the non-production environment.
- The customer hands over tested and verified artifacts to WSO2 to be deployed in the production environment.
- WSO2 ensures the security and availability of the artifacts deployed in the production environment.
- WSO2 is responsible for storing, versioning, updating and removing artifacts in the production environment.
- WSO2 installs software patches and upgrades WSO2 products upon the customer's request. Security patches provided by the OS vendor are installed automatically.
Manage logs and backups
We manage the following types of logs:
- Audit logs: These are generated by the Linux audit daemon and capture all important/privileged system activities.
- Application logs: These are Carbon-level logs that capture all activities related to WSO2 Carbon servers. Carbon is the base platform on top of which all WSO2 products are built.
- System logs: These are Linux syslog and the auth.log files.
Note the following:
- WSO2 uses the Amazon Cloud Watch service to collect and manage logs.
- All log types mentioned above are stored in a private Amazon S3 bucket. An agent in each host collects and streams log events into the S3 bucket.
- If the customer has log management and analysis tools in place, WSO2 can forward the logs to the customer.
- WSO2 stores logs onsite for 30 days and then archive them to Amazon Glacier Vault.
Manage upgrades and migrations
Hand over the environments
WSO2 is to hand over the production environment to the customer with:
- URLs of the WSO2 products deployed in the Managed Cloud.
- Credentials with admin privileges to access the Management Consoles of the WSO2 products.
Tip: Note that WSO2 can facilitate the following upon the customer's request:
Next, go to Support and Maintenance.You can implement your WSO2 Managed Cloud instance in the following ways: