ORLEANS REMOTE DEPLOYMENT
Orleans Remote Deployment
Table of Contents
Overview: 1
Prerequisites. 2
Deployment Steps. 2
Orleans Deployment Manifest 3
Orleans Silo Configuration. 4
Gateway Load Shedding. 5
Orleans Powershell Scripts. 6
Deploying Orleans using Powershell Script 6
Confirming Orleans Status. 7
Monitoring Orleans. 7
Gathering Orleans Log Files. 8
Removing Orleans. 8
Overview:
Orleans based services are xcopy deployable. All you need to do to deploy an Orleans based service to a set of machines is copy the following set of file to the target machines and start the OrleansHost.exe host process:
- · Content of [SDK-Root]\Binaries\OrleansServer folder
- · OrleansConfiguration.xml file with configuration for the deployment to replace the default placeholder from [SDK-Root]\Binaries\OrleansServer
- · Binaries with grain interfaces and grain implementation classes of the service along with any external dependencies to Application\<service name> subdirectory of the folder on the target with binaries from [SDK-Root]\Binaries\OrleansServer
This simple task may be accomplished in many different ways and with different tools, such as Autopilot. The SDK includes a set of PowerShell scripts that provide a way to deploy an Orleans based service to a cluster of machines and remote start the hosting processes on them. There are also scripts for un-deploying a service, monitoring its performance, start and stop it, and collect logs. These are the scripts we found useful for ourselves while building and testing Orleans.
Prerequisites
The following table lists the prerequisites for deploying and running Orleans on a remote machine:
|
Prerequisite |
Details |
|
.Net Framework 4.0 |
Orleans runs under the .Net Framework 4.0, which can be installed from this link: http://www.microsoft.com/downloads/details.aspx?FamilyID=9cfb2d51-5ff4-4491-b0e5-b386f32c0992&displaylang=en |
|
Powershell 2.0 with WinRM |
Windows 7 and Windows Server 2008 R2 should have these installed by default. To confirm you are running the required version of |
|
WinRM Configuration |
Both the source and target machines must be configured winrm quickconfig |
|
Increase PowerShell job memory |
Set the memory limit Set-Item To change it on a
|
|
PowerShell Execution Policy set to run remote scripts |
Open a PowerShell window as an Administrator and run the command Set-ExecutionPolicy RemoteSigned This will set the machine to require signing for remote scripts |
Deployment Steps
Note that the user running the scripts
must be a member of the Administrators Group on the remote machines.
The basic steps are as follows:
1.
Setup a deployment manifest
(Deployment.xml).
2.
Adjust the Orleans
Configuration (OrleansConfiguration.xml) to suit the environment.
3.
Run the PowerShell deployment
scripts to deploy Orleans into your remote environment.
Orleans Deployment Manifest
The Orleans Deployment scripts use a
manifest (XML) file to specify details of the deployment, including source and
destination locations and local or remote machines to be deployed to.
By making small changes to an existing
deployment manifest xml file (typically by listing the different host
machines), the same PowerShell scripts can deploy and run that Orleans system
on a set of remote machines with equal ease as deploying and running that
system on the local machine.
The default file name for the manifest
is Deployment.xml, and if you just modify this file, it will not be necessary
to specify a different name. There are
times, such as during testing, it may be advantageous to maintain multiple
deployment files that specify a different set of silos. These other files may be specified explicitly
to the deployment tools as specified in the respective sections below.
A Deployment manifest contains many
different items, which collectively allow deployment of the Orleans runtime and
applications onto a variety of local and remote configurations:
- ·
Source location for the Orleans system runtime
o Located in the “Path” attribute of the <Deployment><Packages><Package>
element where the “Type” attribute is set to “System”.
o Typically: [ORLEANS-SDK]\Binaries\OrleansServer.
o
Example: <Package Name="Orleans Runtime"
Type="System" Path="." />
- ·
Source location for any
additional Orleans applications / grains
to be included in this Orleans system
o
Also located in the
<Deployment><Packages><Package> nodes.
o
The “Type” attribute must be set to “Application”.
o
Use the “Filter” attribute to
constrain the files deployed
o
<Package
Name="Chirper" Type="Application"
Path="..\Binaries\Applications\Chirper" />
- ·
Source location for the server configuration file to be used by
the Orleans host process
o
Located in the “Path” attribute
<Deployment><RuntimeConfiguration> element.
o
The file name must be OrleansConfiguration.xml – if necessary,
just change the path.
o
Example: <RuntimeConfiguration
Path=".\OrleansConfiguration.xml" />
- ·
Target location to install the Orleans
server-side binaries on each machine.
Typically: C:\Orleans (for test or production nodes) or [ORLEANS-SDK]\LocalSilo (for the local development silo).
o
Located in the <Deployment><TargetLocation>
element.
o
Must be an absolute path (i.e. no “..”
locations).
o
Example: <TargetLocation
Path="C:\Orleans" />
- ·
The set of silos (host machines and optional silo names) this Orleans system
should to be deployed to.
o Located in the <Deployment><Nodes><Node> elements.
o Typically: Primary on localhost, or multiple machines with one silo each.
o The “HostName” attribute specifies the machine name.
o The “NodeName” attribute specifies the name of the silo. Generally, this is arbitrary, with the
exception that if multiple silos will run
on any one machine, then silo names must be unique.
o Example:
<Nodes>
<Node
HostName="MACHINE1" NodeName="Primary" />
<Node
HostName="MACHINE2" NodeName="Node2" />
<Node
HostName="MACHINE3" NodeName="Node3" />
<Nodes />
- ·
Deployment Group ID – this is a GUID
which distinguishes one Orleans runtime system from another, even if both
Orleans systems are running on the same machines.
o
Located in the
<Deployment> element.
o
Example:
<Deployment
Name="Deployment1"
DeploymentGroup="F219832A-1EE1-45DA-B35D-0BB3060C9FDA"
xmlns="urn:xcg-deployment">
Orleans Silo Configuration
Refer to the configuration guide - Orleans-Configuration.docx
- for information on how to configure silos.
Orleans Powershell Scripts
The following sections detail the
PowerShell scripts provided with Orleans to aid with deployment and monitoring.
(Use the /? option to get the latest usage info directly from the scripts.)
|
Script Name |
Parameters |
Description |
|
DeployOrleansSilos.ps1 |
[$deploymentConfigFile] |
Copies the Orleans files to machines specified in the |
|
UndeployOrleansSilos.ps1 |
[$deploymentConfigFile] |
Stops and removes Orleans from the |
|
MonitorOrleansSilos.ps1 |
[$deploymentConfigFile] [$networkInstance] [$repeatHeaderInFile |
Monitors CPU, Memory, Network Send, and |
|
ShowOrleansSilos.ps1 |
[$deploymentConfigFile] |
Does a quick survey of the deployment |
|
GatherOrleansSiloLogs.ps1 |
[$deploymentConfigFile] [$outputPath] |
Retrieve all log files from deployment |
|
UtilityFunctions.ps1 |
none |
Provides ancillary functionality to the |
Deploying Orleans using Powershell
Script
Start a separate
PowerShell command window as an administrator.
Execute the DeployOrleansSilos.ps1script, providing the location of the deployment configuration file
(deployment.xml is the default and will be used if you don’t supply a value).
Examples: .\DeployOrleansSilos.ps1
.\DeployOrleansSilos.ps1
C:\Orleans\MyDeploy.xml
The deployment
will execute the following steps:
1.
Stop any running instances of Orleans that are running on the
deployment machines.
2.
Copy the Orleans files and any application files that are listed in
the deployment manifest.
3.
When the copy is completed, start the silos. This will pause after starting the first silo
so that it is available for the other silos to register with.
4.
Pause to allow the start-up to complete.
5.
Report the progress of the deployment.
When the deployment is complete, Orleans
is ready for clients to connect to it.
Confirming Orleans Status
To determine if Orleans is running on
the servers in the deployment manifest, run the ShowOrleansSilos.ps1 script.
If you have used a deployment manifest
file named something other than the default, specify it on the command line.
Examples:
.\ShowOrleansSilos.ps1
.\ShowOrleansSilos.ps1
C:\Orleans\MyDeploy.xml
Monitoring Orleans
Once Orleans is
deployed, you can start an optional script that will monitor the Orleans
deployment using standard performance counters.
Run a dedicated PowerShell command prompt as an administrator, and
execute the .\MonitorOrleans.ps1
script to start monitor performance counters for an Orleans Deployment.
The following
parameters configure the monitoring to suit individual circumstances:
|
Parameter |
Description |
Default |
|
DeploymentConfigFile |
The deployment manifest used to install |
Deployment.xml |
|
NetworkInstance |
The name of the network for the network performance counters. |
corp |
|
SamplesToLog |
The number of samples to record in the |
480 which taken in one minute intervals |
|
HeaderInterval |
The number of samples to write before repeating the header. |
10 |
|
RepeatHeaderInFile |
If this switch is present, the header will |
Only include the header at the top of the |
The script will
store the data in the following types listed below. The files will be written to a folder called PerformanceData
under the directory where the monitoring script is run from.
|
File |
Description |
FileNameBase |
|
|
Machine Specific |
Contains only the data for a single |
“PerfData-“ + the machine name and the Date/Time stamp. |
|
|
Combined |
Contains all of the data for all machines consolidated into a |
“ConsolidatedPerfData-“ |
|
Gathering Orleans Log Files
To retrieve all log files from
deployment silos and store them in the specified output folder, run the GatherOrleansSiloLogs.ps1 script.
If you have used a deployment manifest
file named something other than the default, specify it on the command line.
You may also specify an output folder where the collected log files will be
stored otherwise a .\logs subdirectory will
be used by default.
Examples:
.\GatherOrleansSiloLogs.ps1
.\GatherOrleansSiloLogs.ps1
C:\Orleans\MyDeploy.xml
.\GatherOrleansSiloLogs.ps1
C:\Orleans\MyDeploy.xml C:\MyLogs
Removing Orleans
When it is time to remove an Orleans
deployment, use the UndeployOrleansSilos.ps1 script.
If you have used a deployment manifest
file named something other than the default, specify it on the command line.
Examples:
.\UnDeployOrleansSilos.ps1
.\UnDeployOrleansSilos.ps1 C:\Orleans\MyDeploy.xml
ORLEANS REMOTE DEPLOYMENT的更多相关文章
- Spark如何使用Akka实现进程、节点通信的简明介绍
<深入理解Spark:核心思想与源码分析>一书前言的内容请看链接<深入理解SPARK:核心思想与源码分析>一书正式出版上市 <深入理解Spark:核心思想与源码分析> ...
- jboss-as 目录结构(转)
jboss-as 目录结构(Directory Structure) Directory Description bin Contains startup, shutdown and other sy ...
- 升级、备份红帽PaaS openshift 上的 wordpress
红帽提供了一个很稳定的PAAS服务平台:openshift!此博客即作为wordpress建在里面. 这里记录怎样升级与备份wordpress. 预备: 安装 openshift command li ...
- Jenkins 七: 部署到Tomcat
在build.xml定义了打包target之后,我们可以将打包生成的war文件直接部署到tomcat. 1. 建立Tomcat用户. 打开Tomcat安装路径下的 conf/tomcat-users. ...
- Java RMI 入门案例
Java Remote Method Invocation(Java RMI) 是一个 Java API, 执行远程方法的调用,相当于 Remote Procedure Calls(RPC).Java ...
- jboss-AS目录结构了解(资料摘取)
Directory Description bin Contains startup, shutdown and other system-specific scripts. Basically al ...
- SPARK如何使用AKKA实现进程、节点通信
SPARK如何使用AKKA实现进程.节点通信 <深入理解Spark:核心思想与源码分析>一书前言的内容请看链接<深入理解SPARK:核心思想与源码分析>一书正式出版上市 < ...
- Akka(9): 分布式运算:Remoting-远程构建式
上篇我们讨论了Akka-Remoting.我们说Akka-Remoting是一种点对点的通讯方式,能使两个不同JVM上Akka-ActorSystem上的两个Actor之间可以相互沟通.Akka-Re ...
- 使用 dotnet core 和 Azure PaaS服务进行devOps开发(Web API 实例)
作者:陈希章 发表于 2017年12月19日 引子 这一篇文章将用一个完整的实例,给大家介绍如何基于dotnet core(微软.NET的最新版本,支持跨平台,跨设备的应用开发,详情请参考 https ...
随机推荐
- 用JQ仿造百度书籍预售页面的单屏滚页效果
今天的项目需要做到一个介绍页面,我主动提出走单屏滚页的风格,毕竟交互性好,逼格也高,具体效果可以参照百度知道书籍预售页面. 其实现效果就大概是这样的: 还是老样子,所有步骤文件可以从我的Github上 ...
- angular.js 例子
angular.js是一个前端的MVC框架,12年的时候曾近在一个portal平台的项目中使用过. 下面给出一个angular.js的典型例子,涵盖一些基础的知识点,用以复习备忘: <html ...
- note of introduction of Algorithms(Lecture 3 - Part1)
Lecture 3(part 1) Divide and conquer 1. the general paradim of algrithm as bellow: 1. divide the pro ...
- 将整数转换成二进制的java小程序
首先我们知道,将整数转换成二进制是将整数除二取余将最后除得的数和得到的余数从下向上写,组成得到的二进制数. java程序实现如下: public class ChangeToErjinzhi { pu ...
- [编译] 1、第一个makefile简单例子
前言 本篇用一个最简单的例子引入makefile,教你编写第一个makefile 正文 在Download/aa文件夹下有a.c和makefile文件 litao@litao:~/Downloads/ ...
- 如何为编程爱好者设计一款好玩的智能硬件(三)——该选什么样的MCU呢?
一.我的构想:如何为编程爱好者设计一款好玩的智能硬件(一)——即插即用.积木化.功能重组的智能硬件模块构想 二.别人家的孩子:如何为编程爱好者设计一款好玩的智能硬件(二)——别人是如何设计硬件积木的! ...
- http学习笔记(二)—— 嘿!伙计,你在哪?(URL)
我们之所以希望浏览网页,其中一个重要的原因就是庞大的web世界中有很丰富的资源,他就像哆啦a梦的口袋,随时都能拿出我们想要的宝贝.这些资源通过http被传送到我们的浏览器,并展示到我们的屏幕上.而我们 ...
- 在XML drawable中引用自定义颜色
== 先看一下一个xml drawable文件,这是一个button的样式. <?xml version="1.0" encoding="utf-8" ? ...
- 诡异的 未处理的IOErrorEvent 2035
今天游戏发布上线之后,总是随机的出现卡死. 换了个safari之后,看到抛了 IOErrorEvent. 问题是,我所有的Loader都加入了contentLoaderInfo监听.而抛出来的又没有堆 ...
- IT传统组织结构及新型扁平化组织
如今互联网企业正凶猛的改变人们衣食住行的方方面面,衣->淘宝,蘑菇街;食->大众点评,口碑;住->去哪,途牛:行->12306, 多次听到互联网的同行介绍他们就是要“快”,快速 ...