因为访问Nuget太慢,在Dotnet Core RC2发布前,我就基于Asp.Net做了一个Nuget代理网站

这是网站地址:http://nuget.lzzy.net/

Nuget源:http://nuget.lzzy.net/api/v2

广西电信百兆带宽。

这个网站将会缓存所有访问过的API页面与包。

API页面缓存的原理,第一次访问会等待服务器从Nuget上下载页面信息

下载后会替换里面的网址并保存到数据库。

第二次访问会从数据库里取出页面兵判断过期时间

如果已过期,先返回页面信息,后台新建线程下载新页面。

这样国内访问的时候就会觉得非常快。

升级至AspNet Core

等到RC2发布后,我觉得,是时候研究Dotnet Core平台了

那么就从这个小小的Nuget代理网站开始吧。

在.Net FX下,开发的代理程序是通过IHttpHandler进行代理的

那么到了AspNet Core,就变成了通过中间件进行代理。

路由在AspNetCore下也变得不同了,使用起来比老版的更方便更简单。

路由的使用

注:路由的使用需要用到包Microsoft.AspNetCore.Routing

首先创建一个静态类,添加一个UseXXXMiddleware扩展方法,这是AspNetCore使用中间件的约定,当然你也可以起其它名字。

在方法里,我们需要new一个RouteBuilder实例。

在实例里调用各种映射方法。

然后调用RouteBuilder的Build方法,这将生成一个路由。

最后再使用路由中间件的扩展方法UseRouter,把刚刚Build出来的路由作为参数传递进去即可。

        public static IApplicationBuilder UseNugetProxyMiddleware(this IApplicationBuilder builder, IConfigurationRoot config)
{
if (!Directory.Exists("Packages"))
Directory.CreateDirectory("Packages"); var cacheSection = config.GetSection("Cache");
_CacheMetadata = int.Parse(cacheSection.GetSection("Metadata").Value);
_CacheList = int.Parse(cacheSection.GetSection("List").Value);
_CacheDetail = int.Parse(cacheSection.GetSection("Detail").Value);
_CacheDefault = int.Parse(cacheSection.GetSection("Default").Value);
var proxySection = config.GetSection("Proxy");
_Source = proxySection.GetSection("Source").Value;
_Replace = proxySection.GetSection("Replace").Value;
_Path = proxySection.GetSection("Path").Value; var routeBuilder = new RouteBuilder(builder);
routeBuilder.MapGet(_Path + "/{action}", PageHandler);
routeBuilder.MapGet(_Path, PageHandler);
routeBuilder.MapGet(_Path + "/package/{id}/{version}", PackageHandler); _Path = "/" + _Path; var router = routeBuilder.Build();
return builder.UseRouter(router);
} private static async Task PageHandler(HttpContext httpContext)
{ }

路由下的中间件使用

使用RouteBuilder的映射方法时,需要传递处理HttpContext的委托

这里其实与AspNet Core本身的中间件方法其实是一样的。

只不过,我们需要在方法里获取各种数据,而不是像AspNet Core中间件一样可以在构造函数里获取到一些服务。

AspNet Core路由提供了HttpContext获取路由参数的扩展方法GetRouteValue。

        private static async Task PackageHandler(HttpContext httpContext)
{ string id = httpContext.GetRouteValue("id") as string;
string version = httpContext.GetRouteValue("version") as string;
}

也有GetRouteData扩展方法,这里我们并不需要用到。

EntityFramework Core

RC2下,EntityFramework Core的使用出现了一些变化

在Startup.cs里,配置EF Core

        public void ConfigureServices(IServiceCollection services)
{
// Add framework services.
services.AddDbContext<DataContext>(builder =>
{
builder.UseSqlServer(Configuration.GetConnectionString("DataContext"));
});
}

在这里修改DbContext的配置。

要注意的是,继承DbContext的类,要使用带参数的构造函数并调用基类构造函数。

    public class DataContext : DbContext
{
public DataContext(DbContextOptions<DataContext> options) : base(options) { } public DbSet<Page> Page { get; set; }
}

互斥锁

多人访问同一个新页面,只能有一个人去下载新页面的数据,其他人则等待。新包同理。

多人访问同一个过期页面,只会创建一个新线程去下载新页面的数据。

项目里封装了一个SynchronizationHelp类,在中间件里通过路径进行互斥处理。

剩下的也没什么特别值得要说的了,一些尽在源码里。

Github

这里是这个代理网站的Github:

https://github.com/Kation/NugetProxy

啊,对了,还有一点。

代理网站的配置。

配置文件:

{
"Logging": {
"IncludeScopes": false,
"LogLevel": {
"Default": "Debug",
"System": "Information",
"Microsoft": "Information"
}
},
"ConnectionStrings": {
"DataContext": "server=(local);database=nuget;uid=sa;pwd=123@abc"
},
"Cache": {
"Metadata": "10080",
"List": "60",
"Detail": "1440",
"Default": "30"
},
"Proxy": {
"Source": "https://www.nuget.org/api/v2",
"Replace": "https://www.nuget.org/api/v2",
"Path": "api/v2"
}
}

可以设定缓存时间,超出时间后才去下载新页面,单位是分钟。

Proxy的Source是Nuget源

Replace是要替换的字符串,将会替换为当前网站地址+Path

PS:我在美国架了一台20M的VPS反向代理Nuget

http://nuget.lzzy.net/api/v2使用的是我的VPS方向代理的源

效果比直接访问Nuget快……

【AspNet Core】Nuget代理网站的更多相关文章

  1. AspNet Core 初步认识

    Core 的出现对我我没有很大的影响,当时在Core要发布的时候听到周围的人再聊再谈,我没有去太多关注,就是一个屌丝开发人员. 直到又一次偶然见到一位特别喜欢.net的老开发人员谈起Core时落泪了, ...

  2. AspNet Core Api Restful +Swagger 发布IIS 实现微服务之旅 (二)

    上一步我们创建好CoreApi 接下来在框架中加入 Swagger  并发布  到 IIS (1)首先点击依赖项>管理Nuget包 (2)输入 Swashbuckle.aspnetCore  比 ...

  3. ASP.NET Core下发布网站

    一.windows下发布到IIS 1.前奏:IIS上的准备 (1)IIS 必须安装AspNetCoreModule 模块 下载地址:(DotNetCore.2.0.3-WindowsHosting-a ...

  4. ASP.NET Core下发布网站图解

    与ASP.NET时代不同,ASP.NET Core不再是由IIS工作进程(w3wp.exe)托管,而是使用自托管Web服务器(Kestrel)运行,IIS则是作为反向代理的角色转发请求到Kestrel ...

  5. AspNet Core Api Restful +Swagger 发布IIS

    上一步我们创建好CoreApi 接下来在框架中加入 Swagger  并发布  到 IIS (1)首先点击依赖项>管理Nuget包 (2)输入 Swashbuckle.aspnetCore  比 ...

  6. AspNet Core使用Mysql一些问题及解决方案

    本文假设的你的AspNet Core 2.2的Web程序通过EntityFrameworkCore连接使用MSSQL数据库,能正常使用. 如何想转为使用Mysql,其实不难. 1.安装Mysql这个简 ...

  7. AspNet Core结合Quartz使用定时任务且通过注入缓存或者配置参数

    一.经常在项目会用到定时任务同步数据或更新缓存等操作,在很久以前我们可能经常会用一个多线程或timer来做定时任务,这样能实现比较简单轻量级的任务:对于任务多且都调用频率不一样的任务,我们都会用到Qu ...

  8. 在 Mac OS 上创建并运行 ASP.NET Core 1.0 网站

    var appInsights=window.appInsights||function(config){ function r(config){t[config]=function(){var i= ...

  9. AspNet Core 下利用普罗米修斯+Grafana构建Metrics和服务器性能的监控 (无心打造文字不喜勿喷谢谢!)

    概述 Prometheus的主要特点 组件 结构图 适用场景 不适用场景 安装node_exporter,系统性能指数收集(收集系统性能情况) 下载文件 解压并复制node_exporter应用程序到 ...

随机推荐

  1. 设置session生存时间问题

    // 在 php.ini 中设置 session.gc_maxlifetime = 1440 (默认) // 或者在 session_start() 前,设置 $lifetime = 86400 , ...

  2. 元素堆叠问题、z-index、position

    多次在项目中遇到html页面元素的非期待重叠错误,多数还是position定位情况下z-index的问题.其实每次解决类似问题思路大致都是一样的,说到底还是对z-index的理解比较模糊,可以解决问题 ...

  3. Entity Framework 简单查询

    前言 首先来简单的复习一下如何使用Code First. 第一步还是先建立一个控制台的应用程序,然后通过Nuget添加Entity Framework.那么同时会给packages.config和Ap ...

  4. nova instance出错:"message": "Proxy error: 502 Read from server failed

    执行 $ nova resize instance1 时候出错: {, "details": " File \"/opt/stack/nova/nova/com ...

  5. Mosquitto pub/sub服务实现代码浅析-主体框架

    Mosquitto 是一个IBM 开源pub/sub订阅发布协议 MQTT 的一个单机版实现(目前也只有单机版),MQTT主打轻便,比较适用于移动设备等上面,花费流量少,解析代价低.相对于XMPP等来 ...

  6. HTTP状态码

    http状态码负责表示客户端HTTP请求的返回结果.标记服务器端的处理是否正常.通知出现的错误等工作. 状态码类别分组如下: 1. 1XX: informational(信息性状态码)  接收的请求正 ...

  7. Mosquitto搭建Android推送服务(三)Mosquitto集群搭建

    文章钢要: 1.进行双服务器搭建 2.进行多服务器搭建 一.Mosquitto的分布式集群部署 如果需要做并发量很大的时候就需要考虑做集群处理,但是我在查找资料的时候发现并不多,所以整理了一下,搭建简 ...

  8. 【日记】搭建一个node本地服务器

    用node搭建一个本地http服务器.首先了解htpp服务器原理 HTTP协议定义Web客户端如何从Web服务器请求Web页面,以及服务器如何把Web页面传送给客户端.HTTP协议采用了请求/响应模型 ...

  9. 最小生成树(prim&kruskal)

    最近都是图,为了防止几次记不住,先把自己理解的写下来,有问题继续改.先把算法过程记下来: prime算法:                  原始的加权连通图——————D被选作起点,选与之相连的权值 ...

  10. node(Buffer缓存区)

    // 创建buffer类 var buf=new buffer(10); var buf=new buffer([10,20,30,40]); var buf=new buffer("www ...