c# 安装windows例子

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Diagnostics;
using System.Linq;
using System.Management;
using System.ServiceProcess;
using System.Text;

namespace KafkaService
{
    public partial class Service1 : ServiceBase
    {
        public Service1()
        {
            InitializeComponent();
        }

        protected override void OnStart(string[] args)
        {
            // TODO: 在此处添加代码以启动服务。
            System.IO.Directory.SetCurrentDirectory(AppDomain.CurrentDomain.BaseDirectory);
            wLog("kafka Service Start");
            startKafka();
        }

        protected override void OnStop()
        {
            // TODO: 在此处添加代码以执行停止服务所需的关闭操作。
            //CloseKafka();
            KillProcessAndChildren(_kafkaProcess.Id);
            wLog("kafka  Service Stop\n");
        }

        Process proc = null;
        private Process _kafkaProcess;
        private void startKafka(Object sender = null, EventArgs e = null)
        {
            /* wLog("KafkaThread 开始");
             string currentDir = System.AppDomain.CurrentDomain.BaseDirectory;
             proc = new Process();
             proc.StartInfo.CreateNoWindow = true;
             proc.StartInfo.FileName = "cmd.exe";
             proc.StartInfo.UseShellExecute = false;
             proc.StartInfo.RedirectStandardError = true;
             proc.StartInfo.RedirectStandardInput = true;
             proc.StartInfo.RedirectStandardOutput = true;
             proc.Start();
             //启动kafka服务
             string volume = System.Windows.Forms.Application.StartupPath.Substring(0, System.Windows.Forms.Application.StartupPath.IndexOf(":"));
             proc.StandardInput.WriteLine("cd " + volume + ":\\kafka\\bin\\windows");
             wLog(volume + ":\\kafka\\bin\\windows");
             proc.StandardInput.WriteLine("kafka-server-start.bat server.properties");
             while (!proc.StandardOutput.EndOfStream)
             {
                 string line = proc.StandardOutput.ReadLine();
                 wLog(line);
             }
             wLog("KafkaThread 结束");
             proc.WaitForExit();*/
            _kafkaProcess = StartProcess(Constants.KafkaProcess);
        }

        private static Process StartProcess(string command)
        {
            var processInfo = new ProcessStartInfo("cmd.exe", "/c " + command)
            {
                CreateNoWindow = true,
                UseShellExecute = false,
                Verb = "runas"
            };

            return Process.Start(processInfo);
        }

        private static void KillProcessAndChildren(int pid)
        {
            using (var searcher = new ManagementObjectSearcher("Select * From Win32_Process Where ParentProcessID=" + pid))
            {
                var managementObjects = searcher.Get();

                foreach (var obj in managementObjects)
                {
                    var managementObject = (ManagementObject)obj;
                    KillProcessAndChildren(Convert.ToInt32(managementObject["ProcessID"]));
                }

                try
                {
                    var proc = Process.GetProcessById(pid);
                    proc.Kill();
                }
                catch (ArgumentException)
                {
                    // Process already exited.
                }
            }
        }

        private void CloseKafka()
        {
            wLog("Kill kafka 服务");
            if (null == proc)
                return;
            proc.Kill();
            proc.Close();
            proc = null;
        }
        private void wLog(string logStr, bool wTime = true)
        {
            using (System.IO.StreamWriter sw = new System.IO.StreamWriter(AppDomain.CurrentDomain.BaseDirectory + "\\autoService.log", true))
            {
                string timeStr = wTime == true ? DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss ") : "";
                sw.WriteLine(timeStr + logStr);
            }
        }

        private void MyProcOutputHandler(object sendingProcess, DataReceivedEventArgs outLine)
        {
            if (!String.IsNullOrEmpty(outLine.Data))
            {
                wLog(outLine.Data, false);
            }
        }
    }
}

namespace KafkaService
{
    public static class Constants
    {
        public static string KafkaVersion
        {
            get { return "0.10.2.1"; }
        }

        public static string KafkaScalaVersion
        {
            get { return "kafka_2.12-" + KafkaVersion; }
        }

        public static string DownloadUrl
        {
            get { return "http://apache.claz.org/kafka/" + KafkaVersion + "/" + KafkaScalaVersion + ".tgz"; }
        }

        public static string TarFileName
        {
            get { return KafkaScalaVersion + ".tgz"; }
        }

        public static string UncompressedTarFileName
        {
            get { return KafkaScalaVersion + ".tar"; }
        }

        public static string RootDirectory
        {
            get { return @"C:\";  }
        }

        public static string RootDirectoryLinux
        {
            get { return @"C:/"; }
        }

        public static string KafkaLocation
        {
            get { return RootDirectory + KafkaScalaVersion;  }
        }

        public static string ZookeeperProcess
        {
            get
            {

                return RootDirectory +
                    KafkaScalaVersion + @"\bin\windows\zookeeper-server-start.bat " + KafkaLocation + @"\config\zookeeper.properties";
            }
        }

        public static string KafkaProcess
        {
            get
            {
                string volume = System.Windows.Forms.Application.StartupPath.Substring(0, System.Windows.Forms.Application.StartupPath.IndexOf(":"));
                return volume + ":\\kafka\\bin\\windows\\kafka-server-start.bat " + volume + ":\\kafka\\config\\server.properties";
            }
        }

        public static string ZookeeperConfig
        {
            get { return RootDirectory + @"\" + KafkaScalaVersion + @"\config\zookeeper.properties"; }
        }

        public static string KafkaConfig
        {
            get { return RootDirectory + @"\" + KafkaScalaVersion + @"\config\server.properties"; }
        }

        public static string DataDir
        {
            get { return RootDirectory + KafkaScalaVersion + @"\data"; }
        }

        public static string LogDir
        {
            get { return RootDirectory + KafkaScalaVersion + @"\kafka-logs"; }
        }

        public static string DataDirLinux
        {
            get { return RootDirectoryLinux + KafkaScalaVersion + @"/data"; }
        }

        public static string LogDirLinux
        {
            get { return RootDirectoryLinux + KafkaScalaVersion + @"/kafka-logs"; }
        }
    }
}
#region

using KafkaService.Installer;
using System;
using System.Diagnostics;
using System.Management;

#endregion

namespace KafkaService
{
    public class KafkaServiceWrapper
    {
        private Process _zookeeperProcess;
        private Process _kafkaProcess;

        public void Start()
        {
            ApacheKafkaInstaller.Install();

            _zookeeperProcess = StartProcess(Constants.ZookeeperProcess);
            _kafkaProcess = StartProcess(Constants.KafkaProcess);
        }

        public void Stop()
        {
            KillProcessAndChildren(_kafkaProcess.Id);
            KillProcessAndChildren(_zookeeperProcess.Id);
        }

        private static Process StartProcess(string command)
        {
            var processInfo = new ProcessStartInfo("cmd.exe", "/c " + command)
            {
                CreateNoWindow = true,
                UseShellExecute = false,
                Verb = "runas"
            };

            return Process.Start(processInfo);
        }

        private static void KillProcessAndChildren(int pid)
        {
            using (var searcher = new ManagementObjectSearcher("Select * From Win32_Process Where ParentProcessID=" + pid))
            {
                var managementObjects = searcher.Get();

                foreach (var obj in managementObjects)
                {
                    var managementObject = (ManagementObject) obj;
                    KillProcessAndChildren(Convert.ToInt32(managementObject["ProcessID"]));
                }

                try
                {
                    var proc = Process.GetProcessById(pid);
                    proc.Kill();
                }
                catch (ArgumentException)
                {
                    // Process already exited.
                }
            }
        }
    }
}
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.IO;
using System.Net;
using System.Text.RegularExpressions;

namespace KafkaService.Installer
{
    /// <summary>
    /// Responsible for downloading and setting up Apache Kafka in the root directory of the program.
    /// </summary>
    public static class ApacheKafkaInstaller
    {
        private const string SEVENZIP_LOCATION = @"Lib\7z.exe";

        /// <summary>
        /// Downloads and sets up Apache Kafka locally in the root directory of the program.
        /// This ensures both Kafka and Zookeeper are configured to work within a Windows environment.
        /// </summary>
        public static void Install()
        {
            DownloadAndExtractKafka();
            SetupWindowsEnvironment();
        }

        private static void DownloadAndExtractKafka()
        {
            if (Directory.Exists(Constants.KafkaLocation))
            {
                Console.WriteLine("{0} already downloaded and extracted", Constants.KafkaLocation);
                return;
            }

            // Delete the extracted file so we can unzip it again.
            DeleteFileIfExists(Constants.UncompressedTarFileName);

            if (!File.Exists(Constants.TarFileName))
            {
                DownloadKafka();
            }

            ExtractKafka();
            MoveKafka();
            DeleteFileIfExists(Constants.UncompressedTarFileName);
            DeleteFileIfExists(Constants.TarFileName);
        }

        private static void DeleteFileIfExists(string filename)
        {
            if (File.Exists(filename))
            {
                File.Delete(filename);
            }
        }

        private static void DownloadKafka()
        {
            using (var client = new WebClient())
            {
                client.DownloadFile(Constants.DownloadUrl, Constants.TarFileName);
            }

            Console.WriteLine("Downloaded {0}", Constants.TarFileName);
        }

        private static void ExtractKafka()
        {
            Process.Start(SEVENZIP_LOCATION, "e " + Constants.TarFileName).WaitForExit();
            Process.Start(SEVENZIP_LOCATION, "x " + Constants.UncompressedTarFileName).WaitForExit();

            Console.WriteLine("Extracted {0} into {1}", Constants.TarFileName, Constants.KafkaScalaVersion);
        }

        private static void MoveKafka()
        {
            string sourceDirectory = Constants.KafkaScalaVersion;
            string destinationDirectory = Constants.KafkaLocation;

            MoveAcrossVolumes(sourceDirectory, destinationDirectory);
        }

        private static void MoveAcrossVolumes(string sourceDirectory, string destinationDirectory)
        {
            foreach (var file in Directory.GetFileSystemEntries(sourceDirectory, "*", SearchOption.AllDirectories))
            {
                var output = Regex.Replace(file, @"^" + sourceDirectory, destinationDirectory);
                if (File.Exists(file))
                {
                    File.Copy(file, output, true);
                }
                else
                {
                    Directory.CreateDirectory(output);
                }
            }
            Directory.Delete(sourceDirectory, true);
        }


        private static void SetupWindowsEnvironment()
        {
            //var dataDir = string.Format("{0}/data", Constants.KafkaScalaVersion);
            //var loggingDir = string.Format("{0}/kafka-logs", Constants.KafkaScalaVersion);

            CreateDirectoryIfNotExists(Constants.DataDir);
            CreateDirectoryIfNotExists(Constants.LogDir);

            ReplaceLineInFile(Constants.ZookeeperConfig, "dataDir=/tmp/zookeeper", "dataDir=" + Constants.DataDirLinux);
            ReplaceLineInFile(Constants.KafkaConfig, "log.dirs=/tmp/kafka-logs", "log.dirs=" + Constants.LogDirLinux);
        }

        private static void CreateDirectoryIfNotExists(string dir)
        {
            if (!Directory.Exists(dir))
            {
                Directory.CreateDirectory(dir);
            }
        }

        private static void ReplaceLineInFile(string filename, string lineToMatch, string replaceWith)
        {
            var fileToOutput = new List<string>();
            using (var inputStream = File.OpenRead(filename))
            using (var inputReader = new StreamReader(inputStream))
            {
                string currentLine;
                while ((currentLine = inputReader.ReadLine()) != null)
                {
                    if (currentLine == lineToMatch)
                    {
                        currentLine = replaceWith;
                    }

                    fileToOutput.Add(currentLine);
                }
            }

            File.WriteAllLines(filename, fileToOutput);
        }
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
资源包主要包含以下内容: ASP项目源码:每个资源包中都包含完整的ASP项目源码,这些源码采用了经典的ASP技术开发,结构清晰、注释详细,帮助用户轻松理解整个项目的逻辑和实现方式。通过这些源码,用户可以学习到ASP的基本语法、服务器端脚本编写方法、数据库操作、用户权限管理等关键技术。 数据库设计文件:为了方便用户更好地理解系统的后台逻辑,每个项目中都附带了完整的数据库设计文件。这些文件通常包括数据库结构图、数据表设计文档,以及示例数据SQL脚本。用户可以通过这些文件快速搭建项目所需的数据库环境,并了解各个数据表之间的关系和作用。 详细的开发文档:每个资源包都附有详细的开发文档,文档内容包括项目背景介绍、功能模块说明、系统流程图、用户界面设计以及关键代码解析等。这些文档为用户提供了深入的学习材料,使得即便是从零开始的开发者也能逐步掌握项目开发的全过程。 项目演示与使用指南:为帮助用户更好地理解和使用这些ASP项目,每个资源包中都包含项目的演示文件和使用指南。演示文件通常以视频或图文形式展示项目的主要功能和操作流程,使用指南则详细说明了如何配置开发环境、部署项目以及常见问题的解决方法。 毕业设计参考:对于正在准备毕业设计的学生来说,这些资源包是绝佳的参考材料。每个项目不仅功能完善、结构清晰,还符合常见的毕业设计要求和标准。通过这些项目,学生可以学习到如何从零开始构建一个完整的Web系统,并积累丰富的项目经验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值