最近服务器SQLServer内存占用率总是超高,每次手动重启服务器太麻烦,于是写一个自动跑的程序,去检查内存使用率,如果Sqlserver内存占用超过一定数值,就将其关闭,重新启动。
测试的时候遇到的第一个问题就是,程序写好了,但是不能关闭服务,并报出“无法启动”的异常,猜测可能是用户权限不够,于是使用管理员身份运行后,可以将服务重启。于是我们需要在程序中加入代码,使得程序判断当前是否是管理员账号,若不是则使用管理员身份启动,具体代码如下:
1.将程序中的Program.cs替换为以下:
[STAThread]
static void Main(string[] Args)
{
//Application.EnableVisualStyles();
//Application.SetCompatibleTextRenderingDefault(false);
//Application.Run(new fmRebootWindowsService());
//获得当前登录的Windows用户标示
System.Security.Principal.WindowsIdentity identity = System.Security.Principal.WindowsIdentity.GetCurrent();
//创建Windows用户主题
Application.EnableVisualStyles();
System.Security.Principal.WindowsPrincipal principal = new System.Security.Principal.WindowsPrincipal(identity);
//判断当前登录用户是否为管理员
if (principal.IsInRole(System.Security.Principal.WindowsBuiltInRole.Administrator))
{
//如果是管理员,则直接运行
Application.EnableVisualStyles();
Application.SetCompatibleTextRenderingDefault(false);
Application.Run(new fmRebootWindowsService());
}
else
{
//创建启动对象
System.Diagnostics.ProcessStartInfo startInfo = new System.Diagnostics.ProcessStartInfo();
//设置运行文件
startInfo.FileName = System.Windows.Forms.Application.ExecutablePath;
//设置启动参数
startInfo.Arguments = String.Join(" ", Args);
//设置启动动作,确保以管理员身份运行
startInfo.Verb = "runas";
//如果不是管理员,则启动UAC
System.Diagnostics.Process.Start(startInfo);
//退出
System.Windows.Forms.Application.Exit();
}
}