بکاپ گرفتن از دیتابیس در برنامه در حال اجرا در Asp.net Core
سلام
بنده یک سامانه دارم که روی سرور یک سازمان در حال فعالیت است. سامانه با Asp.Net Core و دیتابیس آن هم از Sql Server استفاده میکند.
ادمین سیستم خیلی آشنایی خاصی با مفاهیم حرفه ای حوزه آی تی ندارد و صرفا با کامپیوتر و سامانه می تواند خوب کار کند.
بنده قصد دارم در پنل ادمین یک دکمه برای گرفتن بک آپ از دیتابیس قرار بدهم که با کلیک روی آن یک بک آپ در سرور بگیرد و امکان دانلود این بک آپ هم برای ذخیره سازی در یک هارد اکسترنال یا هر جای دیگر به من بدهد. ما به این دلیل که این سازمان از نظر بودجه ای قوی نیست این روش را می خواهیم استفاده کنیم.
ممنون میشم اگه هر کسی راهکاری در این خصوص دارد، بنده را راهنمایی کند.
پاسخ هوش مصنوعی
برای تهیه بکاپ از دیتابیس SQL Server در ASP.NET Core و فراهم کردن امکان دانلود آن، می توانید از کد زیر استفاده کنید:
ابتدا باید یک متد برای گرفتن بکاپ بنویسید:
using System.Data.SqlClient;
using System.IO;
using Microsoft.AspNetCore.Mvc;
public class BackupController : Controller
{
private readonly string _connectionString = "your_connection_string_here";
public IActionResult CreateBackup()
{
string backupFileName = $"Backup_{DateTime.Now:yyyyMMddHHmmss}.bak";
string backupFilePath = Path.Combine("C:\\Backups", backupFileName);
using (SqlConnection connection = new SqlConnection(_connectionString))
{
connection.Open();
SqlCommand command = new SqlCommand($"BACKUP DATABASE [your_database_name] TO DISK = '{backupFilePath}'", connection);
command.ExecuteNonQuery();
}
return File(System.IO.File.ReadAllBytes(backupFilePath), "application/octet-stream", backupFileName);
}
}
در این کد:
- شما باید
your_connection_string_hereوyour_database_nameرا با مقادیر مربوط به دیتابیس خود جایگزین کنید. - به پوشه
C:\Backupsدسترسی نوشتن بدهید یا پوشه مورد نظر خود را انتخاب کنید.
سپس در فایل Startup.cs خود، مطمین شوید که کنترلرها به درستی پیکربندی شده اند:
public void ConfigureServices(IServiceCollection services)
{
services.AddControllersWithViews();
}
در نهایت، دکمه ای در پنل ادمین اضافه کنید که با کلیک بر روی آن، متد CreateBackup اجرا شود:
<a href="@Url.Action("CreateBackup", "Backup")">گرفتن بکاپ</a>
بهترین کار این هست که روی سرور Job ایجاد کنید و به طور منظم بکاپ گیری های خودتون رو تنظیم کنید. لینک زیر رو مطالعه بفرمایید به طور کامل آموزش ایجاد Job روی سرور رو نوشته.
آموزش ایجاد Backup در Sql Server به صورت زمانبندی شده
نکته بعدی اینه که بکاپ فقط روی سرور ایجاد میشه. یعنی شما نمی تونید به صورت ریموت یک بکاپ بگیرید و فایل بکاپ رو جایی غیر از سرور ذخیره سازی کنید. شما نهایتا می تونید فایل های بکاپی که ایجاد شده رو از روی سرور بردارید و به جای دیگه منتقل کنید.
- کار نکردن navBar و sideBar در پروژه Asp.net core
- خطا موقع استفاده از Api در سی شارپ
- آموزش استفاده از پلاگین گردونه شانس در Asp.net core به همراه سورس
- نمایش متن به صورت فرمت شده در CkEditor
- آموزش استفاده از SignalR در Asp.net Core با مثال عملی
- ادغام چند گزارش استیمول سافت بصورت پی دی اف در یک فایل
- نحوه تغییر استایل کامپوننت select2 چگونه است ؟
- چگونه امنیت پروژه را در Asp.net Core افزایش دهیم ؟
- ارسال پارامتر در دستور window.open جی کویری
- ارسال پارامتر از طریق جاوااسکریپت با کلیک روی تگ a
- کار با CkEditor با قابلیت آپلود عکس
- خطا در ایجاد migration در Asp.net core
- تفاوت های Asp.net core و Asp.net mvc چیه؟
- دلیل اسپم شدن ایمیل های ارسالی از سرور
- نحوه لایه بندی پروژه Core و اضافه کردن به IIS
- ارسال ایمیل در Asp.net core
- آیا میشه در mvc core از کامپونت استفاده کرد
- آپلود فایل در Asp.net core چگونه است؟
- حذف کامل یک رکورد در جدول ریلیشن شده
- اشکال در آپلود فایل ویدیو در mvc core 2