نحوه نصب بستر سبد خرید LiteCart در اوبونتو 16.04
LiteCart یک بستر سبد خرید آزاد و منبع باز است که به زبان های PHP ، jQuery و HTML 5 نوشته شده است. این نرم افزار ساده ، سبک و با کاربرد آسان است.
Beanstalk یک صف کار سریع و ساده است. این امکان را به شما می دهد تا کارهای غیر وقت گیر را بصورت غیر همزمان ، مانند ارسال ایمیل ، اتصال به API های خارجی یا پردازش تصاویر انجام دهید. با این کار ، تأخیر برنامه وب خود را کاهش می دهید. Laravel پشتیبانی خارج از جعبه را برای شما فراهم می کند beanstalkd
.
در این آموزش نصب خواهیم کرد beanstalkd
، یک نسخه آزمایشی Laravel را نصب کرده و صف کارگران را از طریق Supervisor مدیریت خواهیم کرد. برنامه نسخه ی نمایشی لیستی از سیستم عامل های موجود را از Vultr API دریافت می کند و بطور تصادفی یکی را انتخاب می کند.
فرض بر این است که شما از قبل Supervisor را روی سیستم خود نصب کرده اید. اگر این کار را نکردید ، باید آموزش زیر را در مورد نحوه راه اندازی Supervisor مطالعه کنید: نصب و پیکربندی سرپرست در اوبونتو 16.04
همچنین فرض بر این است که شما به Sult نمونه Vultr خود دسترسی دارید.
اولین قدم برای نصب ، نصب است beanstalkd
.
sudo apt-get update
sudo apt-get install beanstalkd
خدمات را شروع کنید.
sudo systemctl start beanstalkd
همچنین می توانید این سرویس را با آغاز به کار سیستم فعال کنید.
sudo systemctl enable beanstalkd
وضعیت خدمات را با صدور دستور زیر بررسی کنید.
sudo systemctl status beanstalkd
به طور پیش فرض ، beanstalkd
درگاه را گوش می دهد 11300
. Beanstalk از یک پروتکل مبتنی بر متن ساده که در مخزن آن github استفاده می شود ، استفاده می کند . با اجرای آن می توانید پروتکل آن را تست کنید telnet
.
telnet localhost 11300
موارد زیر را بنویسید و بزنید ENTER.
list-tubes
شما باید لیستی از لوله های موجود در سرور را مشاهده کنید:
OK 14
---
- default
برای بستن اتصال به سادگی تایپ کنید quit
و سپس را فشار دهید ENTER.
لوله های Beanstalk صف های کاری را نشان می دهند. لوبیای سحرآمیز است که اساسا توسط تشکیل شده تولید ، مصرف کنندگان ، شغل و لوله . تولیدکنندگان مشاغل را در یک لوله قرار می دهند تا توسط هر تعداد مصرف کننده مصرف و پردازش شود. توجه داشته باشید که هم تولید کنندگان و هم مصرف کنندگان صرفاً مشتری های سرور Beanstalk هستند و کاملاً مستقل از یکدیگر هستند. از نظر عملی این بدان معنی است که با استفاده از Beanstalk می توانید شغل خود را در برنامه PHP خود ایجاد کنید و به عنوان مثال در یک برنامه NodeJS پردازش کنید. خوشبختانه ، Laravel همه این موارد را خلاصه می کند و یک API بسیار ساده برای اعزام و رسیدگی به مشاغل به ما ارائه می دهد ، همانطور که در ادامه خواهیم دید.
برای ساخت پروژه نمونه ، ابتدا باید وابستگی های آن را نصب کنیم. ما قصد داریم PHP و Composer را نصب کنیم.
sudo apt-get install php php-mbstring php-xml php-common php-zip composer
اکنون این پروژه را بر اساس Laravel 5.5 ایجاد کنید.
composer create-project --prefer-dist laravel/laravel vultr "5.5.*"
بعد cd
به پوشه اخیراً ایجاد شده. ما از این پس کار خواهیم کرد. این پوشه ممکن است بعداً به عنوان ارجاع داده شود PROJECT_ROOT
.
cd vultr/
برای استفاده از Beanstalk در Laravel ، باید یک وابستگی دیگر ، مشتری PHP Beanstalk نصب کنیم.
composer require pda/pheanstalk ~3.0
ما همچنین نیاز به ایجاد یک نمایندگی شغل داریم. در Laravel ، این یک کلاس در داخل app/Jobs
پوشه است. Laravel یک دستور کنسول برای کمک به ما در ایجاد کلاس شغلی دارد. بیایید نمونه کار خود را ایجاد کنیم.
php artisan make:job FindFavoriteOS
app/Jobs/FindFavoriteOS.php
پرونده را به شرح زیر به روز کنید.
<?php
namespace App\Jobs;
use Illuminate\Bus\Queueable;
use Illuminate\Queue\SerializesModels;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Support\Facades\Log;
class FindFavoriteOS implements ShouldQueue
{
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
/**
* Create a new job instance.
*
* @return void
*/
public function __construct()
{
//
}
/**
* Execute the job.
*
* @return void
*/
public function handle()
{
$rawData = file_get_contents('https://api.vultr.com/v1/os/list');
$list = json_decode($rawData, true);
shuffle($list);
$key = array_rand($list);
$favorite = $list[$key];
Log::info('My Favorite OS is: ' . $favorite['name']);
}
}
روش دسته همان چیزی است که هنگام کار شغل به طور مؤثر اجرا خواهد شد. در اینجا ، ما از داده های Vultr API واکشی می کنیم ، به طور تصادفی یک سیستم عامل را انتخاب می کنیم و سیستم عامل انتخاب شده را روی پرونده log می نویسیم. پرونده log در واقع است storage/logs/laravel.log
.
ما قبلاً Beanstalk را نصب کرده ایم و کار را برای اجرای آن تعریف کرده ایم. اکنون زمان آن رسیده است که به لاراول بگوییم از Beanstalk به عنوان صف کار پیش فرض استفاده کند. .env
پرونده پیش فرض تهیه شده توسط نصب Laravel را کپی کنید .
cp .env.example .env
اکنون .env
پرونده را باز کرده و خطی را که درایور صف مشخص شده است به روز کنید.
QUEUE_DRIVER=beanstalkd
در آخر ، یک کلید برنامه ایجاد کنید.
php artisan key:generate
اکنون ما آماده اعزام مشاغل به صف کار Beanstalk هستیم.
اعزام به کار در لاراول بسیار ساده است. routes/web.php
پرونده را به روز کنید.
<?php
Route::get('/', function () {
for ($i = 0; $i < 50; $i++) {
\App\Jobs\FindFavoriteOS::dispatch();
}
return '50 Jobs dispatched!';
});
علیرغم اینکه به شما توصیه نمی شود که سرور داخلی ساخته شده را تولید کنید ، ما به خاطر کوتاه بودن از آن استفاده خواهیم کرد.
php artisan serve --host 0.0.0.0 --port 8000
اکنون در یک مرورگر وب ، به مسیر بروید http://[vultr-instance-ip]:8000
. پیام زیر را مشاهده خواهید کرد.
50 Jobs dispatched!
یک اتصال جدید SSH به سرور خود و در داخل ریشه پروژه ما باز کنید ، موارد زیر را اجرا کنید.
php artisan queue:work --once
این خروجی مورد انتظار است:
[2018-02-14 00:03:52] Processing: App\Jobs\FindFavoriteOS
[2018-02-14 00:03:53] Processed: App\Jobs\FindFavoriteOS
تأیید کنید که ورود به سیستم ایجاد شده است.
cat storage/logs/laravel.log
برای جلوگیری از نیاز به پردازش دستی صف ، ما از آن استفاده خواهیم کرد supervisord
. پیکربندی برنامه زیر را در ایجاد کنید /etc/supervisor/conf.d/vultr.conf
.
[program:vultr]
process_name=%(program_name)s_%(process_num)02d
command=php [PROJECT_ROOT]/artisan queue:work
autostart=true
autorestart=true
numprocs=8
redirect_stderr=true
stdout_logfile=/var/log/worker.log
توجه کنید که مسیر درست برای قرار دادن پرونده پیکربندی Supervisor به تنظیم شما بستگی دارد. همچنین ، به یاد داشته باشید که جایگزین [PROJECT_ROOT]
مسیر کامل PROJECT_ROOT
سیستم روی سیستم شوید.
در اینجا ما در حال پیکربندی Supervisor هستیم تا به طور خودکار پردازش صف را شروع کرده و در صورت شکستن اسکریپت ، مجدداً آن را راه اندازی کند. همچنین توجه داشته باشید که ما یک کارگر تنها را فوری نمی کنیم بلکه 8 فرآیند را انجام می دهیم. شما می توانید بسته به برنامه خود ، بلافاصله بسیاری از فرآیندهای لازم را فوری کنید.
برای اینکه سرپرست بتواند کارگر ما را مدیریت کند ، مجبور می شویم پیکربندی خود را دوباره بخواند.
sudo supervisorctl reread
sudo supervisorctl update
اگر سرویس Supervisor شروع نشده است ، بسیاری از افراد نیاز به راه اندازی آن دارند.
sudo systemctl start supervisord
حال بیایید ببینیم که آیا مشاغل در حال پردازش هستند یا خیر.
tail -f storage/logs/laravel.log
در یک مرورگر وب ، به حرکت کنید http://[vultr-instance-ip]:8000
. گزارش های موجود در کنسول خود را مشاهده خواهید کرد.
ما با موفقیت برنامه Laravel پیکربندی کرده ایم تا از Beanstalk به عنوان یک صف کار استفاده کند. همچنین ، ما نحوه استفاده از ناظر را برای مدیریت کارگران نشان دادیم.
LiteCart یک بستر سبد خرید آزاد و منبع باز است که به زبان های PHP ، jQuery و HTML 5 نوشته شده است. این نرم افزار ساده ، سبک و با کاربرد آسان است.
با استفاده از یک سیستم متفاوت؟ Anchor CMS یک سیستم مدیریت محتوا (CMS) بسیار ساده و بسیار سبک ، بسیار آزاد و آزاد است.
NFS یک سیستم فایل مبتنی بر شبکه است که به رایانه ها اجازه می دهد تا از طریق شبکه رایانه ای به فایلها دسترسی پیدا کنند. این راهنما توضیح می دهد که چگونه می توانید پوشه ها را روی NF قرار دهید
هنگام راه اندازی سرور جدید لینوکس ، به روزرسانی سیستم های هسته و سایر بسته ها تا آخرین نسخه پایدار یک روش توصیه شده است. در این مقاله
با استفاده از یک سیستم متفاوت؟ Matomo (سابقا پیویک) یک بستر تحلیلی منبع باز است ، یک جایگزین باز برای Google Analytics. منبع Matomo میزبان o
TeamTalk یک سیستم کنفرانس است که به کاربران امکان می دهد مکالمات صوتی / تصویری با کیفیت بالا ، چت متنی ، انتقال فایل ها و صفحه های به اشتراک بگذارند. من
Vultr یک ویژگی را فراهم می کند که به شما امکان می دهد با ایجاد یک نمونه جدید ، کلیدهای SSH را از قبل نصب کنید. این اجازه می دهد تا به کاربر root دسترسی داشته باشید ، با این حال ، th
با استفاده از یک سیستم متفاوت؟ NodeBB یک نرم افزار انجمن مبتنی بر Node.js است. از سوکت های وب برای تعامل فوری و اعلامیه های زمان واقعی استفاده می کند. NodeB
ZNC یک پیشرانه پیشرفته شبکه IRC است که تمام وقت بهم متصل می شود تا مشتری IRC بتواند بدون از دست دادن جلسه گپ قطع یا وصل شود.
رنجر یک مدیر فایل مبتنی بر خط فرمان است که دارای کلیدهای اتصال VI است. این برنامه یک رابط لعنتی مینیمالیستی و زیبا با نمای سلسله مراتب فهرست ارائه می دهد