澳门美高梅手机网站C#异步批量下载文件

 

 

————–博客地址—————————————————————————————

博客地址 http://www.cnblogs.com/double-K/

 

 欢迎转载,请注明出处,谢谢!


2.先期打一个Windows窗体:FrmBatchDownload,加载事件FrmBatchDownload_Load

题材浅析

  用到采访文件我直入主题,查看日志的增强情况、写副状态、问题时间点等信息

  澳门美高梅手机网站 1

 

  以日记的分红空间我们了解及日志是当11接触43分横闪电式暴增一直增长及13触及左右达到240G

  澳门美高梅手机网站 2

 

  分配空间啊是同样的情景在11接触43分左右暴增,后期在1触及半之暴跌就是日记备份让动用空间为放飞。

  澳门美高梅手机网站 3

  

  日志文件的刻画副乎称这时间点,在11触及43分横形容副高达40MB/秒,并且不止了1个多小时。

  澳门美高梅手机网站 4

 

   通过就几乎布置图,我们蛮清晰的即能够一定到日志暴增的时间点,下面要找到相应时间点的语句即可!

  我之排查思路有点不同,持续1独钟头之写入,必然伴随着日志文件的增高(文件增长设置固定值100MB),这里要领取一下:这即是一贯增长之补,因为当及240G
如果依照默认10%增高,那么等同不行索要追加24G
磁盘已经没那么多空间,则会招致报错,系统中断!

  回到排查思路,这里自己直接翻相应时间点系的等待状态:

  澳门美高梅手机网站 5

 

  直接找到日志文件增长的等候类型,查看运行的说话确实运行时是于11碰15届13沾15,和日志增长之图景符合!!

  就如此,只费了10分钟即固定及题目,找到语句,由于存储过程加密,我无能为力看到中的代码,但是暴增的讲话已经找到,需要软件厂商自行处理啦!!

  就是如此概括,打得了收工!所以不用放大了这么的题目排查!

作者:曾庆雷
出处:http://www.cnblogs.com/zengqinglei
本页版权归作者和博客园所有,欢迎转载,但未经作者同意必须保留此段声明, 且在文章页面明显位置给出原文链接,否则保留追究法律责任的权利

容描述

  本案例是一个老大熟的ERP厂商的出品,接到用户紧急电话,说他们日志突然暴增磁盘告警,50G的数据库日志已经高达200G。

  澳门美高梅手机网站 6

 

  看这有些看官可能会见说,肯定是没定时做日志备份导致日志不断变充分!或者说才200G
一点呢不甚呀!

  没错,日志不备卖缺失会发生这般的题材,但当下景象是小儿科,不会见将出去写案例的,200G
确实为不杀,但如若分场景,在是客户平均10独G 的面貌下
200G曾是爆炸式的题材了!

  为什么会拿出来写案例,就是盖想只要告诉大家排查这样问题的思路,不要吃这样的暴增单纯的游说成突发事态!

 

总结

  系统运维就是保证系统平稳运行的办事,看似简单但里面奥妙与心酸只有运维人才能够体会,不要放了各一个细节,一个概括突发情况处理恐怕引出一雨后春笋问题,而化解这些问题同时是保证系统平稳运作基础,请吃运维人多有关爱吧,比如春节来只坏红包,哇哈哈哈哈!!

  有的伴儿就起来春节休假了,祝大家新春快乐,系统安全!

 —————————————————————————————————-

横流:此篇吧原创,欢迎转载,请以篇章页面明显位置为有此文链接!
使您认为就首文章还不易请点击下右侧下角的推荐,非常感谢!

交者批量下蛋充斥功能实现竣工,上面写的代码比较灵敏,需要之情人可以因自己的型修改有关内容。

前言

  本篇文章写以新春佳节前夕,也是为IT运维朋友一个不容忽视,在春节长假前请妥善体检自己的系统安心过单年。

  千里之堤毁于蚁穴,一长条看似简单的讲话就能够拖延垮整个体系,您的SQL
Server很漫长无体检了咔嚓? 就比如相同块藏着刀的蛋糕!怎能安度春节?

  日志暴增的问题处理过很多,这无非是怪正常的一样不成,但是对无是杀娴熟的运维兄弟,可能日志暴增这样的题材会见被一带而过,或者说成突发事态要休去处理,那么隐患还是留存,在春节这般的长假来可怎么处置呢?

 

  本文使用的家伙:SQL专家云平台专业体检工具 :www.zhuancloud.com

废话不多说,先看掩饰效果:

后怕

  为什么说非克放过这么问题的排查!!!

  首先,这个系统正准备及集群,集群大家还理解单机变多雅,必然关系到数的同台,同步是如生消耗的,对勾副的习性会有影响,细心之小伙伴可能都观望这讲话消耗了聊资源,逻辑读,写,影响行数有微微了

  澳门美高梅手机网站 7

 

  没错,64亿的逻辑读!为什么会有这么深之日记,导致暴增!因为写副1亿蹩脚,影响行数19亿,并且实施之时刻不是当夜间之维护期,而是以中午11点15始发,这么深的拍卖在集群方案安排之时段势必要高度警醒,这么可怜的同步量完全可能造成集群严重推迟,甚至宕机!所以就不就是一样软日志暴增问题之排查了,也是针对系统功能尤为细致的打听,如果这么的问题尚未及早发现,就算集群后期测试为非必然会于测试到,进而导致集群上线后底悲催。

 

 

PS:继逻辑读 23亿,34亿,45亿后这案例来刷新了自己表现了的不过特别逻辑读 64亿!

  纪念一下

 

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
#region 命名空间

using System.Threading;
using System.Runtime.InteropServices;
using System.Net;
using System.Collections;

#endregion

namespace WinBatchDownload
{
    public partial class FrmBatchDownload : Form
    {
        #region 全局成员

        //存放下载列表
        List<SynFileInfo> m_SynFileInfoList;

        #endregion

        #region 构造函数

        public FrmBatchDownload()
        {
            InitializeComponent();
            m_SynFileInfoList = new List<SynFileInfo>();
        }

        #endregion

        #region 窗体加载事件

        private void FrmBatchDownload_Load(object sender, EventArgs e)
        {
            //初始化DataGridView相关属性
            InitDataGridView(dgvDownLoad);
            //添加DataGridView相关列信息
            AddGridViewColumns(dgvDownLoad);
            //新建任务
            AddBatchDownload();
        }

        #endregion

        #region 添加GridView列

        /// <summary>
        /// 正在同步列表
        /// </summary>
        void AddGridViewColumns(DataGridView dgv)
        {
            dgv.Columns.Add(new DataGridViewTextBoxColumn()
            {
                DataPropertyName = "DocID",
                HeaderText = "文件ID",
                Visible = false,
                Name = "DocID"
            });
            dgv.Columns.Add(new DataGridViewTextBoxColumn()
            {
                AutoSizeMode = DataGridViewAutoSizeColumnMode.None,
                DataPropertyName = "DocName",
                HeaderText = "文件名",
                Name = "DocName",
                Width = 300
            });
            dgv.Columns.Add(new DataGridViewTextBoxColumn()
            {
                DataPropertyName = "FileSize",
                HeaderText = "大小",
                Name = "FileSize",
            });
            dgv.Columns.Add(new DataGridViewTextBoxColumn()
            {
                DataPropertyName = "SynSpeed",
                HeaderText = "速度",
                Name = "SynSpeed"
            });
            dgv.Columns.Add(new DataGridViewTextBoxColumn()
            {
                DataPropertyName = "SynProgress",
                HeaderText = "进度",
                Name = "SynProgress"
            });
            dgv.Columns.Add(new DataGridViewTextBoxColumn()
            {
                DataPropertyName = "DownPath",
                HeaderText = "下载地址",
                Visible = false,
                Name = "DownPath"
            });
            dgv.Columns.Add(new DataGridViewTextBoxColumn()
            {
                DataPropertyName = "SavePath",
                HeaderText = "保存地址",
                Visible = false,
                Name = "SavePath"
            });
            dgv.Columns.Add(new DataGridViewTextBoxColumn()
            {
                DataPropertyName = "Async",
                HeaderText = "是否异步",
                Visible = false,
                Name = "Async"
            });
        }

        #endregion

        #region 添加下载任务并显示到列表中

        void AddBatchDownload()
        {
            //清空行数据
            dgvDownLoad.Rows.Clear();
            //添加列表(建立多个任务)
            List<ArrayList> arrayListList = new List<ArrayList>();
            arrayListList.Add(new ArrayList(){
                "0",//文件id
                "PPTV客户端.exe",//文件名称
                "21.2 MB",//文件大小
                "0 KB/S",//下载速度
                "0%",//下载进度
                "http://download.pplive.com/pptvsetup_3.2.1.0076.exe",//远程服务器下载地址
                "D:\\PPTV客户端.exe",//本地保存地址
                true//是否异步
            });
            arrayListList.Add(new ArrayList(){
                "1",
                "PPS客户端.exe",
                "14.3 MB",
                "0 KB/S",
                "0%",
                "http://download.ppstream.com/ppstreamsetup.exe",
                "D:\\PPS客户端.exe",
                true
            });
            arrayListList.Add(new ArrayList(){
                "2",
                "美图看看客户端.exe",
                "4.1 MB",
                "0 KB/S",
                "0%",
                "http://kankan.dl.meitu.com/V2/1029/KanKan_kk360Setup.exe",
                "D:\\美图看看客户端.exe",
                true
            });
            foreach (ArrayList arrayList in arrayListList)
            {
                int rowIndex = dgvDownLoad.Rows.Add(arrayList.ToArray());
                arrayList[2] = 0;
                arrayList.Add(dgvDownLoad.Rows[rowIndex]);
                //取出列表中的行信息保存列表集合(m_SynFileInfoList)中
                m_SynFileInfoList.Add(new SynFileInfo(arrayList.ToArray()));
            }
        }

        #endregion

        #region 开始下载按钮单机事件

        private void btnStartDownLoad_Click(object sender, EventArgs e)
        {
            //判断网络连接是否正常
            if (isConnected())
            {
                //设置不可用
                btnStartDownLoad.Enabled = false;
                //设置最大活动线程数以及可等待线程数
                ThreadPool.SetMaxThreads(3, 3);
                //判断是否还存在任务
                if (m_SynFileInfoList.Count <= 0) AddBatchDownload();
                foreach (SynFileInfo m_SynFileInfo in m_SynFileInfoList)
                {
                    //启动下载任务
                    StartDownLoad(m_SynFileInfo);
                }
            }
            else
            {
                MessageBox.Show("网络异常!");
            }
        }

        #endregion

        #region 检查网络状态

        //检测网络状态
        [DllImport("wininet.dll")]
        extern static bool InternetGetConnectedState(out int connectionDescription, int reservedValue);
        /// <summary>
        /// 检测网络状态
        /// </summary>
        bool isConnected()
        {
            int I = 0;
            bool state = InternetGetConnectedState(out I, 0);
            return state;
        }

        #endregion

        #region 使用WebClient下载文件

        /// <summary>
        /// HTTP下载远程文件并保存本地的函数
        /// </summary>
        void StartDownLoad(object o)
        {
            SynFileInfo m_SynFileInfo = (SynFileInfo)o;
            m_SynFileInfo.LastTime = DateTime.Now;
            //再次new 避免WebClient不能I/O并发 
            WebClient client = new WebClient();
            if (m_SynFileInfo.Async)
            {
                //异步下载
                client.DownloadProgressChanged += new DownloadProgressChangedEventHandler(client_DownloadProgressChanged);
                client.DownloadFileCompleted += new AsyncCompletedEventHandler(client_DownloadFileCompleted);
                client.DownloadFileAsync(new Uri(m_SynFileInfo.DownPath), m_SynFileInfo.SavePath, m_SynFileInfo);
            }
            else client.DownloadFile(new Uri(m_SynFileInfo.DownPath), m_SynFileInfo.SavePath);
        }

        /// <summary>
        /// 下载进度条
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        void client_DownloadProgressChanged(object sender, DownloadProgressChangedEventArgs e)
        {
            SynFileInfo m_SynFileInfo = (SynFileInfo)e.UserState;
            m_SynFileInfo.SynProgress = e.ProgressPercentage + "%";
            double secondCount = (DateTime.Now - m_SynFileInfo.LastTime).TotalSeconds;
            m_SynFileInfo.SynSpeed = FileOperate.GetAutoSizeString(Convert.ToDouble(e.BytesReceived / secondCount), 2) + "/s";
            //更新DataGridView中相应数据显示下载进度
            m_SynFileInfo.RowObject.Cells["SynProgress"].Value = m_SynFileInfo.SynProgress;
            //更新DataGridView中相应数据显示下载速度(总进度的平均速度)
            m_SynFileInfo.RowObject.Cells["SynSpeed"].Value = m_SynFileInfo.SynSpeed;
        }

        /// <summary>
        /// 下载完成调用
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        void client_DownloadFileCompleted(object sender, AsyncCompletedEventArgs e)
        {
            //到此则一个文件下载完毕
            SynFileInfo m_SynFileInfo = (SynFileInfo)e.UserState;
            m_SynFileInfoList.Remove(m_SynFileInfo);
            if (m_SynFileInfoList.Count <= 0)
            {
                //此时所有文件下载完毕
                btnStartDownLoad.Enabled = true;
            }
        }

        #endregion

        #region 需要下载文件实体类

        class SynFileInfo
        {
            public string DocID { get; set; }
            public string DocName { get; set; }
            public long FileSize { get; set; }
            public string SynSpeed { get; set; }
            public string SynProgress { get; set; }
            public string DownPath { get; set; }
            public string SavePath { get; set; }
            public DataGridViewRow RowObject { get; set; }
            public bool Async { get; set; }
            public DateTime LastTime { get; set; }

            public SynFileInfo(object[] objectArr)
            {
                int i = 0;
                DocID = objectArr[i].ToString(); i++;
                DocName = objectArr[i].ToString(); i++;
                FileSize = Convert.ToInt64(objectArr[i]); i++;
                SynSpeed = objectArr[i].ToString(); i++;
                SynProgress = objectArr[i].ToString(); i++;
                DownPath = objectArr[i].ToString(); i++;
                SavePath = objectArr[i].ToString(); i++;
                Async = Convert.ToBoolean(objectArr[i]); i++;
                RowObject = (DataGridViewRow)objectArr[i];
            }
        }

        #endregion

        #region 初始化GridView

        void InitDataGridView(DataGridView dgv)
        {
            dgv.AutoGenerateColumns = false;//是否自动创建列
            dgv.AllowUserToAddRows = false;//是否允许添加行(默认:true)
            dgv.AllowUserToDeleteRows = false;//是否允许删除行(默认:true)
            dgv.AllowUserToResizeColumns = false;//是否允许调整大小(默认:true)
            dgv.AllowUserToResizeRows = false;//是否允许调整行大小(默认:true)
            dgv.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.Fill;//列宽模式(当前填充)(默认:DataGridViewAutoSizeColumnsMode.None)
            dgv.BackgroundColor = System.Drawing.Color.White;//背景色(默认:ControlDark)
            dgv.BorderStyle = BorderStyle.Fixed3D;//边框样式(默认:BorderStyle.FixedSingle)
            dgv.CellBorderStyle = DataGridViewCellBorderStyle.SingleHorizontal;//单元格边框样式(默认:DataGridViewCellBorderStyle.Single)
            dgv.ColumnHeadersBorderStyle = DataGridViewHeaderBorderStyle.None;//列表头样式(默认:DataGridViewHeaderBorderStyle.Single)
            dgv.ColumnHeadersHeightSizeMode = DataGridViewColumnHeadersHeightSizeMode.DisableResizing;//是否允许调整列大小(默认:DataGridViewColumnHeadersHeightSizeMode.EnableResizing)
            dgv.ColumnHeadersHeight = 30;//列表头高度(默认:20)
            dgv.MultiSelect = false;//是否支持多选(默认:true)
            dgv.ReadOnly = true;//是否只读(默认:false)
            dgv.RowHeadersVisible = false;//行头是否显示(默认:true)
            dgv.SelectionMode = DataGridViewSelectionMode.FullRowSelect;//选择模式(默认:DataGridViewSelectionMode.CellSelect)
        }

        #endregion

        #region 文件相关操作类分

        /// <summary>
        /// 文件有关的操作类
        /// </summary>
        public class FileOperate
        {
            #region 相应单位转换常量

            private const double KBCount = 1024;
            private const double MBCount = KBCount * 1024;
            private const double GBCount = MBCount * 1024;
            private const double TBCount = GBCount * 1024;

            #endregion

            #region 获取适应大小

            /// <summary>
            /// 得到适应大小
            /// </summary>
            /// <param name="size">字节大小</param>
            /// <param name="roundCount">保留小数(位)</param>
            /// <returns></returns>
            public static string GetAutoSizeString(double size, int roundCount)
            {
                if (KBCount > size) return Math.Round(size, roundCount) + "B";
                else if (MBCount > size) return Math.Round(size / KBCount, roundCount) + "KB";
                else if (GBCount > size) return Math.Round(size / MBCount, roundCount) + "MB";
                else if (TBCount > size) return Math.Round(size / GBCount, roundCount) + "GB";
                else return Math.Round(size / TBCount, roundCount) + "TB";
            }

            #endregion
        }

        #endregion
    }
}

1.新建项目:WinBatchDownload

实现原理:采用WebClient进行批量下载任务,简单的法迅雷下充斥效果!

具体落实步骤如下:

澳门美高梅手机网站 8

4.放置一个DataGridView:dgvDownLoad.

末了附上源码:WinBatchDownload.zip

3.停一个Button按钮:btnStartDownLoad,单机事件btnStartDownLoad_Click

5.实际代码如下:

发表评论

电子邮件地址不会被公开。 必填项已用*标注