{
    "componentChunkName": "component---src-templates-issues-tsx",
    "path": "/issues/8",
    "result": {"data":{"issuesJson":{"id":"d715f0dc-879b-5946-93ce-5f93046bf0b8","title":"acmesh-official/acme.sh: 实现了 acme 协议，可以从 ZeroSSL，Let's Encrypt 等 CA 生成免费的证书。","number":8,"bodyHTML":"<div align=\"center\" dir=\"auto\">\n<p dir=\"auto\"><a target=\"_blank\" rel=\"noopener noreferrer nofollow\" href=\"https://camo.githubusercontent.com/a15b413168923d02e21292705ceaf86b92675f98e250c5c896a02ba7504a6eae/68747470733a2f2f63646e2e6a7364656c6976722e6e65742f67682f657279616a662f7475406d61696e2f696d672f696d6167655f32303234303432305f3231343430382e676966\"><img src=\"https://camo.githubusercontent.com/a15b413168923d02e21292705ceaf86b92675f98e250c5c896a02ba7504a6eae/68747470733a2f2f63646e2e6a7364656c6976722e6e65742f67682f657279616a662f7475406d61696e2f696d672f696d6167655f32303234303432305f3231343430382e676966\" width=\"100%\" height=\"3\" data-animated-image=\"\" data-canonical-src=\"https://cdn.jsdelivr.net/gh/eryajf/tu@main/img/image_20240420_214408.gif\" style=\"max-width: 100%; height: auto; max-height: 3px;\"></a><br><br></p>\n<markdown-accessiblity-table><table role=\"table\">\n<thead>\n<tr>\n<th align=\"right\">Repos</th>\n<th align=\"left\"><a href=\"https://github.com/acmesh-official/acme.sh\">acmesh-official/acme.sh</a></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td align=\"right\"><strong>Views</strong></td>\n<td align=\"left\"><a href=\"https://github.com/opsre/awesome-ops\"><img src=\"https://camo.githubusercontent.com/f0c8a37ca6b48ebc5bd58b8652e4da65ae49e287b2bc8ae2e87e66d52f1bd858/68747470733a2f2f76696577732e77686174696c656172656e65642e746f6461792f76696577732f6769746875622f61636d6573682d6f6666696369616c2f61636d652e73682e737667\" alt=\"views\" data-canonical-src=\"https://views.whatilearened.today/views/github/acmesh-official/acme.sh.svg\" style=\"max-width: 100%;\"></a></td>\n</tr>\n<tr>\n<td align=\"right\"><strong>Stars</strong></td>\n<td align=\"left\"><a href=\"https://github.com/opsre/awesome-ops\"><img src=\"https://camo.githubusercontent.com/28f0d58d4a14da587394ee4af1daefe18e4a477d3ee37449cbe1c821337d8012/68747470733a2f2f696d672e736869656c64732e696f2f6769746875622f73746172732f61636d6573682d6f6666696369616c2f61636d652e73683f636f6c6f723d663266303864266c6f676f3d556e64657274616c65266c6f676f436f6c6f723d656234363330\" alt=\"stars\" data-canonical-src=\"https://img.shields.io/github/stars/acmesh-official/acme.sh?color=f2f08d&amp;logo=Undertale&amp;logoColor=eb4630\" style=\"max-width: 100%;\"></a></td>\n</tr>\n<tr>\n<td align=\"right\"><strong>Forks</strong></td>\n<td align=\"left\"><a href=\"https://github.com/opsre/awesome-ops\"><img src=\"https://camo.githubusercontent.com/39006e7b7f73666900338e325ac8ce8654d80ce9e68738de24348639394ed30e/68747470733a2f2f696d672e736869656c64732e696f2f6769746875622f666f726b732f61636d6573682d6f6666696369616c2f61636d652e73683f636f6c6f723d626138366562266c6f676f3d48616e647368616b65266c6f676f436f6c6f723d656136616136\" alt=\"forks\" data-canonical-src=\"https://img.shields.io/github/forks/acmesh-official/acme.sh?color=ba86eb&amp;logo=Handshake&amp;logoColor=ea6aa6\" style=\"max-width: 100%;\"></a></td>\n</tr>\n<tr>\n<td align=\"right\"><strong>License</strong></td>\n<td align=\"left\"><a href=\"https://github.com/opsre/awesome-ops\"><img src=\"https://camo.githubusercontent.com/e0ae94c0ed6d2a5973ee5640bee5124dd0f5ede12401f875c4998ef021dcf5f4/68747470733a2f2f696d672e736869656c64732e696f2f6769746875622f6c6963656e73652f61636d6573682d6f6666696369616c2f61636d652e73683f6c6f676f3d64617461253341696d616765253246706e672533426261736536342532436956424f5277304b47676f414141414e53556845556741414144414141414177434159414141425841766d48414141414358424957584d41414173544141414c457745416d70775941414144336b6c45515652346e4f335953557a5555426748384a726f57567255474a66456d3773584e63534446784d544c327069347348456778654e526f77586770455742445552522532424e414e4f4b4f4b36366f6f4b4a4742586545475263574163455646475152484677516d483525324630774861655748493944554455354c356b6e6568644f62377a66652532423139636e434a47495243516945596c514237594a4979474c38616f73756c565a36695246516a69474b6b7564576735614c6c704f70704e586e665071773555304459524a6d56786a4367464633424c755a476d416f5655694b4541726d583744375553677351706f72674761336748664b34483663754262435644334771683141352532424c6745253242467749656e514d306a6f446f66714c6f48564e7742796d384370546e416d327a51713073676478624964515a556c416b7150415a3664676a303541446f59526f6f66792532466f5869726f376b3551586a4c6f70677a4b69514e6c4c4461716f4967754577426a7a7150355066446a45394479495879493633464d547751464d43567271774e61763451666f52673538514625324266724d485172454b3844546f434d714e4179574e4866786d54526f4c4f726d5352566747744466714345715a4f4851727a6f34706243557341333431365169364551394b476a6345465267484f724f4b6e5536574162396247455459656b4b7843766a546167394534706a653534446b3551503862624d4859762532464333756541654a6b50304f4778422532424a70426e4172595238455951516e6f4e31414e4661426e5050356c385372736559514c303641646b30464a5938484f5761424d6c6541486a683068506f73497a6c6f3876304125324633345a694f6548726130714b52504d5653493774762532423932747725324676687855654252713456454c674d376642714b354770526d6f514c584e7075625475367a6f4e52706754386e5051627138347764253246494375767978694b4871694e41664933774d367549684271476b4c696977414f734b44714f68743749747239567938536a52424557667941627225324668523142667056514664484a42253246423268683778376a36517077435665655951326b72554235436c636a3641326d3067576a25324244306d4c34397a573563517943484c4e37726a6c6d6d6174457958582532464372547a412532466f51785a6b576c39474a5443566f25324279546a3837253242346769504b6376307149486f344156344430565a727251493334706e70524d36357875652532467a417265453425324654253246536f676c664542794d7369517441546c4c3352414a355948725378365a44665337307337754d486842705225324659423573305057366f455270316236253246667252684b3353444c35546965364f515548516c5133735644752532427a50636b397657453973747225324236496a533967486d5750616861444a25324277434b364e494242587348423948796b587378774470686c436d416476706c6162554a4e6e5a504239342532464e7436784f6538587a4562503257684d335741673147756236744825324233513150673337365239713475716c6e6f36676448476a444f5139306562303141484d3672596975554a314f713472344656756a35765239427a4d3957674e764f7977446869495951467667626366774166774d764863615067425041253246447948476a50624e394138616d6562636477416444354e6633373574787165774e5552656f797677424958594c645170576c6877465771745061435044334173467541535636717171496c62304a766b564331464c39576b4c55556c55574b337a585a4c46432532423125324642726f46746f364f7358497545594a5034447a7a5732594656316f4a614141414141456c46546b5375516d4343\" alt=\"license\" data-canonical-src=\"https://img.shields.io/github/license/acmesh-official/acme.sh?logo=data%3Aimage%2Fpng%3Bbase64%2CiVBORw0KGgoAAAANSUhEUgAAADAAAAAwCAYAAABXAvmHAAAACXBIWXMAAAsTAAALEwEAmpwYAAAD3klEQVR4nO3YSUzUUBgH8JroWVrUGJfEm7sXNcSDFxMTL2pi4sHEgxeNRowXgpEWBDURR%2BNANOKOK66ooKJGBXeEGRcWAcEVFGQRHFwQmH5%2F0wHaeWHI9DUDU5L5knehdOb7zfe%2B19cnCJGIRCQiEYlQB7YJIyGL8aosulVZ6iRFQjiGKkudWg5aLlpOppNXnfPqw5U0DYRJmVxjCgFF3BLuZGmAoVUiKEArmX7D7USgsQporgGa3gHfK4H6cuBbCVD3Gqh1A5%2BLgE%2BFwIenQM0joDofqLoHVNwBym8CpTnAm2zQq0sgdxbIdQZUlAkqPAZ6dgj05ADoYRoofy%2FoXiro7k5QXjLopgzKiQNlLDaqoIguEwBjzqP5PfDjE9DyIXyI63FMTwQFMCVrqwNav4QfoRg58QF%2BfrMHQrEK8DToCMqNAyWNHfxmTRoLOrmSRVgGtDfqCEqZOHQrzo4pbCUsA3416Qi6EQ9KGjcEFRgHOrOKnU6WAb9bGETYekKxCvjTag9E4pje54Dk5QP8bbMHYv%2FC3ueAeJkP0OGxB%2BJpBnArYR8EYQQnoN1ANFaBnPP5l8SrseYQL06Adk0FJY8HOWaBMleAHjh0hPosIzlo8v0A%2F34ZiOeHra0qKRPMVSI7tv%2B92tw%2FvhxUeBRq4VELgM7fBqK5GpRmoQLXNpubTu6zoNRpgT8nPQbq84wd%2FICuvyxiKHqiNAfI3wM6uIhBqGkLiiwAOsKDqOht7Itr9Vy8SjRBEWfyAbr%2FhR1BfpVQFdHJB%2FB2hh7x7j6QpwCVeeYQ2krUB5Clcj6A2m0gWj%2BD0mL49zW5cQyCHLN7rjlmmatEyXX%2FCrTzA%2FoQxZkWl9GJTCVo%2ByTj87%2B4giPKcv0qIHo4AV4D0VZrrQI34pnpRM65xue%2FzAreE4%2FT%2FSoglfEByMsiQtATlL3RAJ5YHrSx6ZDfS70s7uMHhBpR%2FYB5s0PW6oERp1b6%2FfrRhK3SDL5Tie6OQUHQlQ3sVDu%2BzPck9vWE9str%2B6IjS9gHmWPahaDJ%2BwCK6NIBBXsHB9HykXsxwDphlCmAdvplabUJNnZPB94%2FNt6xOe8XzEbP2WhM3WAg1Gub6tH%2B3Q1Pg376R9q4uqlno6gdHGjDOQ90eb01AHM6rYiuUJ1Oq4r4FVuj5vR9BzM9WgNvOywDhiIYQFvgbcfwAfwMvHcaPgBPA%2FDyHGjPbN9A8amebcdwAdD5Nf375txqewNUReoyvwBIXYLdQpWlhwFWqtPaCPD3AsFuASV6qqqIlb0JvkVC1FL9WkLUUlUWK3zXZLFC%2B1%2FBroFto6OsXIuEYJP4DzzW2YFV1oJaAAAAAElFTkSuQmCC\" style=\"max-width: 100%;\"></a></td>\n</tr>\n<tr>\n<td align=\"right\"><strong>UpdatedAt</strong></td>\n<td align=\"left\"><a href=\"https://github.com/opsre/awesome-ops\"><img src=\"https://camo.githubusercontent.com/f6887f5b957e5d0e5b0ee98bcff4d32e341a14ead526e9eb0018a44a31edb145/68747470733a2f2f696d672e736869656c64732e696f2f6769746875622f6c6173742d636f6d6d69742f61636d6573682d6f6666696369616c2f61636d652e73683f646973706c61795f74696d657374616d703d636f6d6d6974746572266c6f676f3d64617461253341696d616765253246706e672533426261736536342532436956424f5277304b47676f414141414e5355684555674141414234414141416543415941414141374d4b3669414141414358424957584d41414173544141414c457745416d7077594141414648556c45515652346e4c5658375539615678776d3236646c582532466468627825324232253246516e626b7655627264554151674a4a496655444e574454546d4f76314651554661504a346b7573725630314a7431734e70637453327533626f745a746d786439744a5346536f714b71494635625944464c436f76436c656673747a4a387758524c445a4c7a6e6b634f343535376e3364332532466e655a3472454f515a74315771462532423858467234253242664f4c4565326a6f59307a776638546f795a50766a45676b4c592532426b306d6d72584f36644b696e787a476b30666a5430782532425279723055716e6359637a4d317263347451253242497270324c4758646f344e4334567657715453373277716c632532427231334f527269364b6458646e624f484c6c776c7a4a70524b6e3657342532424b36706f4f434e6e494166486a253246253242776168495a4234764b6e715a6630714a704e49716c2532467638545530634e6c3572627963337730516e54703379324c54614a374d314e617844723266526e315370504736476961323174664533345463614f617931694d55564f5146624659714957536f31573854694156616e43306576584f4542375770313448466232327a453566714c4f433545524c515769644e614e49347545636339693768634a6c644868324e57725135674464624f6c7061756d49754c62326174415144506e7a3062384e6257636d785656524a33486d7870536377777a4f4a6d4b44524765384c6c435a444c4739673754496e5631516c376462586256316533675430574b697243466f6d6b5079767758466c5a474a4f6a563625324253743634757564445a4f55354555636f782532464d455144567674364d62634e3237593341797a687633737061557242365a3971724a534f3139657a6a387032704c426b4a792532426343484a7857493567573574636652527a31645531394766476b6f7539505a4f34736d52396a4746777065783444793362766e6d4b79706f74625531335669646a71595a68726a343972764d457425324625324659714c7a396430304e6a57253246637a67796f394f35317a7336614e6c6f354644747530445a675146686c47584a30644241446f4e6864367576703657686f617967374e394c564748386d443462253246486e667455516f4e4734764c51306769784d716c5725324234714f6a744e48446733723166365969525347785279375576714c62395534716b716e78504f4e7661356c447048723125324279794b524e4b57425a793565644d554842326d3572792532422532424551772532427a6766347a6f39253246306f634e3357527a4c4277344a2532424a7950574372716d4967475974554f735744346f785a46516f50556a4770564871493425324661666b51504336665a5165654d31253242764c7549516e6a754257514444437363726d485039656f4e5041744271664f6e5875614b25324268364a45624772732532427076764d6d78654962683836336162565065597953456f39464a48704e4d464a59253242503563575a6b6667374f3174537759436553514c54593345385130392532464256504a556c78516a7368543142736343593032723955445542667643484236367063665041336c794165336e6772332532463437584467614a7a736c7937787741364e5a746c555550437541487161536a5549502532427375653842525741432532464e6651374a5a505a35397330476a3756747049537a34685125324243706658474d4b685a63764c70554b7866574d386f68766637702532464f446a4842666356463849736b383267314648796b63564645253242555a414158343761452532464d6c34504f3530506e75683025324678346e6d637957507364774468427836436d6b4c562532466746446a594b784f4a4f4674623077517949684c39527943774b33414f664947703159464542686e4d4a634c525745624b644b516f55366e63545a6b494544696341792532463831645675454d3552775066657934784f7830496b25324649324e6e466b692532425761664f6f464959466367595a43797864376543556a626334416d46363566742532466b4d686b336f25324235686337734d4a79716a4a45477659466151464972375930775077384246415925324236253242766d6b3377367a7a5275444d6d5a5652736668385274413075455453443775434254364459514e36697665553066706b594c6a453671725672744f78654e4b553954484c5a4a396b4255324a427342685635416976422532466f4b61514e4b675043427744596149665a4334616454684f71463457454e56694c4a77566f586f62664c424b56773637414f6154734c6336355461564b32317651344c613939654b6359673576627873624f627a5451394e37554b4467554f3177446a6944494942736868357a746733396e514d4c535a4248344f7a424f55444551586d323036643366634c67737762585141345068634b336e6873775531427a3877765130395248472532466f597933656a6677424e6d746f59714c4130586741414141424a52553545726b4a676767253344253344266c6162656c3d557064617465644174\" alt=\"last-commit\" data-canonical-src=\"https://img.shields.io/github/last-commit/acmesh-official/acme.sh?display_timestamp=committer&amp;logo=data%3Aimage%2Fpng%3Bbase64%2CiVBORw0KGgoAAAANSUhEUgAAAB4AAAAeCAYAAAA7MK6iAAAACXBIWXMAAAsTAAALEwEAmpwYAAAFHUlEQVR4nLVX7U9aVxwm26dlX%2Fdhbx%2B2%2FQnbkvUbrdUAQgJJIfUDNWDTTmOv1FQUFaPJ4kusrV01Jt1sNpctS2u3botZtmxd9tJSFSoqKqIF5bYDFLCovClefstzJ8wXRLDZLznkcO4557n3d3%2FneZ4rEOQZt1WqF%2B8XFr4%2BfOLEe2joY0zwf8ToyZPvjEgkLY%2Bk0mmrXO6dKinxzGk0fjT0x%2BRyr0UqncYczM1rc4tQ%2BIrp2LGXdo4NC4VvWqTS72wqlc%2Br13ORri6KdXdnbOHLlwlzJpRKn6W4%2BK6poOCNnIAfHj%2F%2BwahIZB4vKnqZf0qJpNIql%2Fv8TU0cNl5rbyc3w0QnTp3y2LTaJ7M1NaxDr2fRn1SpPG6Gia21tfE34TcaOay1iMUVOQFbFYqIWSo1W8TiAVanC0evXOEB7Wp14HFb22zE5fqLOC5ERLQWidNaNI4uEcc9i7hcJldHh2NWrQ5gDdbOlpaumIuLb2atAQDPnz0b8NbWcmxVVRJ3HmxpScwwzOJmKDRGe8LlCZDLG9g7TInV1Ql7dbXbV1e3gT0WKirCFomkPyvwXFlZGJOjV6%2BSt64uudDZOU5EUcox%2FMEQDVvt6MbcN27Y3Ayzhv3spaUrB6Z9qrJSO19ezj8p2pLBkJy%2BcCHJxWI5gW5tcfRRz1dU19GfGkou9PZO4smR9jGFwpex4Dy3bvnmKypotbU13VidjqYZhrj49rvMEt%2F%2FYqLz9d00NjW%2Fczgyo9O51zs6aNlo5FDtu0DZgQFhlGXJ0dBADoNhd6uvp6Whoayg7N9LVGH8mD4b%2FHnftUQoNG4vLQ0gixMqlW%2B4qOjtNHDg3r1f6YiRSGxRy7UvqLb9U4qkqnxPONva5lDpHr1%2ByyKRNKWBZy5edMUHB2m5ry%2B%2BEQw%2Bzgf4zo9%2F0ocN3WRzLBw4J%2BJyPWCrqmIgGYtUOsWD4oxZFQoPUjGpVHqI4%2FafkQPC6fZQeeM1%2BvLuIQnjuBWQDDCscrmHP9eoNPAtBqfOnXuaK%2Bh6JEbGrs%2BpvvMmxeIbh863abVPeYySEo9FJHpNMFJY%2BP5cWZkfg7O1tSwYCeSQLTY3E8Q09%2FBVPJUlxQjshT1BscCY02r9UDUBfvCHB66pcfPA3lyAe3ngr3%2F47XDgaJzsly7xwA6NZtlUUPCuAHqaSjUIP%2Bsue8BRWAC%2FNfQ7JZPZ59s0Gj7VtpISz4hQ%2BCpfXGMKhZcvLpUKxfWM8ohvf7p%2FODjHBfcVF8Isk82g1FHykcVFE%2BUZAAX47aE%2FMl4PO50Pnuh0%2Fx4nmcyWPsdwDhBx6CmkLV%2FgFDjYKxOJOFtb0wQyIhL9RyCwK3AOfIGp1YFEBhnMJcLRWEbKdKQoU6ncTZkIEDicAy%2F81dVuEM5RwPfey4xOx0Ik%2FI2NnFki%2BWafOoFIYFcgYZCyxd7eCUjbc4AmF65ft%2FkMhk3o%2B5hc7sMJyqjJEGvYFaQFIr7Y0wPw8BFAY%2B6%2Bvmk3w6zzRuDMmZVRsfh8RtA0uETSD7uCBT6DYQN6iveU0fpkYLjE6qrVrtOxeNKU9THLZJ9kBU2JBsBhV5AivB%2FoKaQNKgPCBwDYaIfZC4adThOqF4WENViLJwVoXobfLBKVw67AOaTsLc65TaVK21vQ4La99eKcYg5vbxsbObzTQ9N7UKDgUO1wDjiDIIBshh5ztg39nQMLSZBH4OzBOUDEQXm206d3fcLgswbXQA4PhcK3nhswU1Bz8wvQ09RHG%2FoYy3ejfwBNmtoYqLA0XgAAAABJRU5ErkJggg%3D%3D&amp;label=UpdatedAt\" style=\"max-width: 100%;\"></a></td>\n</tr>\n<tr>\n<td align=\"right\"><strong>CreatedAt</strong></td>\n<td align=\"left\"><a href=\"https://github.com/opsre/awesome-ops\"><img src=\"https://camo.githubusercontent.com/9fe282cd31dda7ace051bebad8f6844e6840d4e495d60ff0dd13164a80533231/68747470733a2f2f696d672e736869656c64732e696f2f6769746875622f637265617465642d61742f61636d6573682d6f6666696369616c2f61636d652e73683f6c6f676f3d64617461253341696d616765253246706e672533426261736536342532436956424f5277304b47676f414141414e5355684555674141414234414141416543415941414141374d4b3669414141414358424957584d41414173544141414c457745416d7077594141414648556c45515652346e4c5658375539615678776d3236646c582532466468627825324232253246516e626b7655627264554151674a4a496655444e574454546d4f76314651554661504a346b7573725630314a7431734e70637453327533626f745a746d786439744a5346536f714b71494635625944464c436f76436c656673747a4a387758524c445a4c7a6e6b634f343535376e3364332532466e655a3472454f515a74315771462532423858467234253242664f4c4565326a6f59307a776638546f795a50766a45676b4c592532426b306d6d72584f36644b696e787a476b30666a5430782532425279723055716e6359637a4d317263347451253242497270324c4758646f344e4334567657715453373277716c632532427231334f527269364b6458646e624f484c6c776c7a4a70524b6e3657342532424b36706f4f434e6e494166486a253246253242776168495a4234764b6e715a6630714a704e49716c2532467638545530634e6c3572627963337730516e54703379324c54614a374d314e617844723266526e315370504736476961323174664533345463614f617931694d55564f5146624659714957536f31573854694156616e43306576584f4542375770313448466232327a453566714c4f433545524c515769644e614e49347545636339693768634a6c644868324e57725135674464624f6c7061756d49754c62326174415144506e7a3062384e6257636d785656524a33486d7870536377777a4f4a6d4b44524765384c6c435a444c4739673754496e5631516c376462586256316533675430574b697243466f6d6b5079767758466c5a474a4f6a563625324253743634757564445a4f55354555636f782532464d455144567674364d62634e3237593341797a687633737061557242365a3971724a534f3139657a6a387032704c426b4a792532426343484a7857493567573574636652527a31645531394766476b6f7539505a4f34736d52396a4746777065783444793362766e6d4b79706f74625531335669646a71595a68726a343972764d457425324625324659714c7a396430304e6a57253246637a67796f394f35317a7336614e6c6f354644747530445a675146686c47584a30644241446f4e6864367576703657686f617967374e394c564748386d443462253246486e667455516f4e4734764c51306769784d716c5725324234714f6a744e48446733723166365969525347785279375576714c62395534716b716e78504f4e7661356c447048723125324279794b524e4b57425a793565644d554842326d3572792532422532424551772532427a6766347a6f39253246306f634e3357527a4c4277344a2532424a7950574372716d4967475974554f735744346f785a46516f50556a4770564871493425324661666b51504336665a5165654d31253242764c7549516e6a754257514444437363726d485039656f4e5041744271664f6e5875614b25324268364a45624772732532427076764d6d78654962683836336162565065597953456f39464a48704e4d464a59253242503563575a6b6667374f3174537759436553514c54593345385130392532464256504a556c78516a7368543142736343593032723955445542667643484236367063665041336c794165336e6772332532463437584467614a7a736c7937787741364e5a746c555550437541487161536a5549502532427375653842525741432532464e6651374a5a505a35397330476a3756747049537a34685125324243706658474d4b685a63764c70554b7866574d386f68766637702532464f446a4842666356463849736b383267314648796b63564645253242555a414158343761452532464d6c34504f3530506e75683025324678346e6d637957507364774468427836436d6b4c562532466746446a594b784f4a4f4674623077517949684c39527943774b33414f664947703159464542686e4d4a634c525745624b644b516f55366e63545a6b494544696341792532463831645675454d3552775066657934784f7830496b25324649324e6e466b692532425761664f6f464959466367595a43797864376543556a626334416d46363566742532466b4d686b336f25324235686337734d4a79716a4a45477659466151464972375930775077384246415925324236253242766d6b3377367a7a5275444d6d5a5652736668385274413075455453443775434254364459514e36697665553066706b594c6a453671725672744f78654e4b553954484c5a4a396b4255324a427342685635416976422532466f4b61514e4b675043427744596149665a4334616454684f71463457454e56694c4a77566f586f62664c424b56773637414f6154734c6336355461564b32317651344c613939654b6359673576627873624f627a5451394e37554b4467554f3177446a6944494942736868357a746733396e514d4c535a4248344f7a424f55444551586d323036643366634c67737762585141345068634b336e6873775531427a3877765130395248472532466f597933656a6677424e6d746f59714c4130586741414141424a52553545726b4a676767253344253344266c6162656c3d437265617465644174\" alt=\"create-at\" data-canonical-src=\"https://img.shields.io/github/created-at/acmesh-official/acme.sh?logo=data%3Aimage%2Fpng%3Bbase64%2CiVBORw0KGgoAAAANSUhEUgAAAB4AAAAeCAYAAAA7MK6iAAAACXBIWXMAAAsTAAALEwEAmpwYAAAFHUlEQVR4nLVX7U9aVxwm26dlX%2Fdhbx%2B2%2FQnbkvUbrdUAQgJJIfUDNWDTTmOv1FQUFaPJ4kusrV01Jt1sNpctS2u3botZtmxd9tJSFSoqKqIF5bYDFLCovClefstzJ8wXRLDZLznkcO4557n3d3%2FneZ4rEOQZt1WqF%2B8XFr4%2BfOLEe2joY0zwf8ToyZPvjEgkLY%2Bk0mmrXO6dKinxzGk0fjT0x%2BRyr0UqncYczM1rc4tQ%2BIrp2LGXdo4NC4VvWqTS72wqlc%2Br13ORri6KdXdnbOHLlwlzJpRKn6W4%2BK6poOCNnIAfHj%2F%2BwahIZB4vKnqZf0qJpNIql%2Fv8TU0cNl5rbyc3w0QnTp3y2LTaJ7M1NaxDr2fRn1SpPG6Gia21tfE34TcaOay1iMUVOQFbFYqIWSo1W8TiAVanC0evXOEB7Wp14HFb22zE5fqLOC5ERLQWidNaNI4uEcc9i7hcJldHh2NWrQ5gDdbOlpaumIuLb2atAQDPnz0b8NbWcmxVVRJ3HmxpScwwzOJmKDRGe8LlCZDLG9g7TInV1Ql7dbXbV1e3gT0WKirCFomkPyvwXFlZGJOjV6%2BSt64uudDZOU5EUcox%2FMEQDVvt6MbcN27Y3Ayzhv3spaUrB6Z9qrJSO19ezj8p2pLBkJy%2BcCHJxWI5gW5tcfRRz1dU19GfGkou9PZO4smR9jGFwpex4Dy3bvnmKypotbU13VidjqYZhrj49rvMEt%2F%2FYqLz9d00NjW%2Fczgyo9O51zs6aNlo5FDtu0DZgQFhlGXJ0dBADoNhd6uvp6Whoayg7N9LVGH8mD4b%2FHnftUQoNG4vLQ0gixMqlW%2B4qOjtNHDg3r1f6YiRSGxRy7UvqLb9U4qkqnxPONva5lDpHr1%2ByyKRNKWBZy5edMUHB2m5ry%2B%2BEQw%2Bzgf4zo9%2F0ocN3WRzLBw4J%2BJyPWCrqmIgGYtUOsWD4oxZFQoPUjGpVHqI4%2FafkQPC6fZQeeM1%2BvLuIQnjuBWQDDCscrmHP9eoNPAtBqfOnXuaK%2Bh6JEbGrs%2BpvvMmxeIbh863abVPeYySEo9FJHpNMFJY%2BP5cWZkfg7O1tSwYCeSQLTY3E8Q09%2FBVPJUlxQjshT1BscCY02r9UDUBfvCHB66pcfPA3lyAe3ngr3%2F47XDgaJzsly7xwA6NZtlUUPCuAHqaSjUIP%2Bsue8BRWAC%2FNfQ7JZPZ59s0Gj7VtpISz4hQ%2BCpfXGMKhZcvLpUKxfWM8ohvf7p%2FODjHBfcVF8Isk82g1FHykcVFE%2BUZAAX47aE%2FMl4PO50Pnuh0%2Fx4nmcyWPsdwDhBx6CmkLV%2FgFDjYKxOJOFtb0wQyIhL9RyCwK3AOfIGp1YFEBhnMJcLRWEbKdKQoU6ncTZkIEDicAy%2F81dVuEM5RwPfey4xOx0Ik%2FI2NnFki%2BWafOoFIYFcgYZCyxd7eCUjbc4AmF65ft%2FkMhk3o%2B5hc7sMJyqjJEGvYFaQFIr7Y0wPw8BFAY%2B6%2Bvmk3w6zzRuDMmZVRsfh8RtA0uETSD7uCBT6DYQN6iveU0fpkYLjE6qrVrtOxeNKU9THLZJ9kBU2JBsBhV5AivB%2FoKaQNKgPCBwDYaIfZC4adThOqF4WENViLJwVoXobfLBKVw67AOaTsLc65TaVK21vQ4La99eKcYg5vbxsbObzTQ9N7UKDgUO1wDjiDIIBshh5ztg39nQMLSZBH4OzBOUDEQXm206d3fcLgswbXQA4PhcK3nhswU1Bz8wvQ09RHG%2FoYy3ejfwBNmtoYqLA0XgAAAABJRU5ErkJggg%3D%3D&amp;label=CreatedAt\" style=\"max-width: 100%;\"></a></td>\n</tr>\n</tbody>\n</table></markdown-accessiblity-table>\n<a href=\"https://github.com/opsre/awesome-ops\">\n</a><p dir=\"auto\"><a href=\"https://github.com/opsre/awesome-ops\"><img src=\"https://camo.githubusercontent.com/b964a36ea4078c39f603d46a29436371c7541a2f26e0228d7b21b9d9805b43d3/68747470733a2f2f736f6369616c6966792e6769742e63692f6f707372652f617765736f6d652d6f70732f696d6167653f6465736372697074696f6e3d3126666f6e743d42697474657226666f726b733d31266973737565733d31266c616e67756167653d31266c6f676f3d6874747073253341253246253246617661746172732e67697468756275736572636f6e74656e742e636f6d25324675253246313838353638303230266e616d653d31266f776e65723d31267061747465726e3d436972637569742b426f6172642670756c6c733d31267374617267617a6572733d31267468656d653d4c69676874\" alt=\"\" data-canonical-src=\"https://socialify.git.ci/opsre/awesome-ops/image?description=1&amp;font=Bitter&amp;forks=1&amp;issues=1&amp;language=1&amp;logo=https%3A%2F%2Favatars.githubusercontent.com%2Fu%2F188568020&amp;name=1&amp;owner=1&amp;pattern=Circuit+Board&amp;pulls=1&amp;stargazers=1&amp;theme=Light\" style=\"max-width: 100%;\"></a></p>\n<a target=\"_blank\" rel=\"noopener noreferrer nofollow\" href=\"https://camo.githubusercontent.com/a15b413168923d02e21292705ceaf86b92675f98e250c5c896a02ba7504a6eae/68747470733a2f2f63646e2e6a7364656c6976722e6e65742f67682f657279616a662f7475406d61696e2f696d672f696d6167655f32303234303432305f3231343430382e676966\"><img src=\"https://camo.githubusercontent.com/a15b413168923d02e21292705ceaf86b92675f98e250c5c896a02ba7504a6eae/68747470733a2f2f63646e2e6a7364656c6976722e6e65742f67682f657279616a662f7475406d61696e2f696d672f696d6167655f32303234303432305f3231343430382e676966\" width=\"100%\" height=\"3\" data-animated-image=\"\" data-canonical-src=\"https://cdn.jsdelivr.net/gh/eryajf/tu@main/img/image_20240420_214408.gif\" style=\"max-width: 100%; height: auto; max-height: 3px;\"></a>\n</div>\n<h1 dir=\"auto\">An ACME Shell script: acme.sh</h1>\n<p dir=\"auto\"><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/FreeBSD.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/FreeBSD.yml/badge.svg\" alt=\"FreeBSD\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/OpenBSD.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/OpenBSD.yml/badge.svg\" alt=\"OpenBSD\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/NetBSD.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/NetBSD.yml/badge.svg\" alt=\"NetBSD\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/MacOS.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/MacOS.yml/badge.svg\" alt=\"MacOS\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Ubuntu.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Ubuntu.yml/badge.svg\" alt=\"Ubuntu\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Windows.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Windows.yml/badge.svg\" alt=\"Windows\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Solaris.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Solaris.yml/badge.svg\" alt=\"Solaris\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/DragonFlyBSD.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/DragonFlyBSD.yml/badge.svg\" alt=\"DragonFlyBSD\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Omnios.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Omnios.yml/badge.svg\" alt=\"Omnios\" style=\"max-width: 100%;\"></a></p>\n<p dir=\"auto\"><a target=\"_blank\" rel=\"noopener noreferrer\" href=\"https://github.com/acmesh-official/acme.sh/workflows/Shellcheck/badge.svg\"><img src=\"https://github.com/acmesh-official/acme.sh/workflows/Shellcheck/badge.svg\" alt=\"Shellcheck\" style=\"max-width: 100%;\"></a><br>\n<a target=\"_blank\" rel=\"noopener noreferrer\" href=\"https://github.com/acmesh-official/acme.sh/workflows/PebbleStrict/badge.svg\"><img src=\"https://github.com/acmesh-official/acme.sh/workflows/PebbleStrict/badge.svg\" alt=\"PebbleStrict\" style=\"max-width: 100%;\"></a><br>\n<a target=\"_blank\" rel=\"noopener noreferrer\" href=\"https://github.com/acmesh-official/acme.sh/workflows/Build%20DockerHub/badge.svg\"><img src=\"https://github.com/acmesh-official/acme.sh/workflows/Build%20DockerHub/badge.svg\" alt=\"DockerHub\" style=\"max-width: 100%;\"></a></p>\n<p dir=\"auto\"><a href=\"https://opencollective.com/acmesh\" alt=\"Financial Contributors on Open Collective\" rel=\"nofollow\"><img src=\"https://camo.githubusercontent.com/1c9be08570ff3a3811385d0409d6e9d7f36fc5a7483df26c25f1870f8e71f5e5/68747470733a2f2f6f70656e636f6c6c6563746976652e636f6d2f61636d6573682f616c6c2f62616467652e7376673f6c6162656c3d66696e616e6369616c2b636f6e7472696275746f7273\" data-canonical-src=\"https://opencollective.com/acmesh/all/badge.svg?label=financial+contributors\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://gitter.im/acme-sh/Lobby?utm_source=badge&amp;utm_medium=badge&amp;utm_campaign=pr-badge&amp;utm_content=badge\" rel=\"nofollow\"><img src=\"https://camo.githubusercontent.com/da8a5d6b9712c5cdca0a3678726506d7fd99a7bc49b7a0bd9555be9c6049bb62/68747470733a2f2f6261646765732e6769747465722e696d2f61636d652d73682f4c6f6262792e737667\" alt=\"Join the chat at https://gitter.im/acme-sh/Lobby\" data-canonical-src=\"https://badges.gitter.im/acme-sh/Lobby.svg\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://hub.docker.com/r/neilpang/acme.sh\" title=\"Click to view the image on Docker Hub\" rel=\"nofollow\"><img src=\"https://camo.githubusercontent.com/8a1a85ed86fcdd4fdc3c44d49a2967ef9fca4a48f88b65b5ca1a626c886d3fad/68747470733a2f2f696d672e736869656c64732e696f2f646f636b65722f73746172732f6e65696c70616e672f61636d652e73682e737667\" alt=\"Docker stars\" data-canonical-src=\"https://img.shields.io/docker/stars/neilpang/acme.sh.svg\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://hub.docker.com/r/neilpang/acme.sh\" title=\"Click to view the image on Docker Hub\" rel=\"nofollow\"><img src=\"https://camo.githubusercontent.com/018482335d03f06a2a9b8a5778720de8d3f60a434a04472216b3776eb9b088b4/68747470733a2f2f696d672e736869656c64732e696f2f646f636b65722f70756c6c732f6e65696c70616e672f61636d652e73682e737667\" alt=\"Docker pulls\" data-canonical-src=\"https://img.shields.io/docker/pulls/neilpang/acme.sh.svg\" style=\"max-width: 100%;\"></a></p>\n<ul dir=\"auto\">\n<li>An ACME protocol client written purely in Shell (Unix shell) language.</li>\n<li>Full ACME protocol implementation.</li>\n<li>Support ECDSA certs</li>\n<li>Support SAN and wildcard certs</li>\n<li>Simple, powerful and very easy to use. You only need 3 minutes to learn it.</li>\n<li>Bash, dash and sh compatible.</li>\n<li>Purely written in Shell with no dependencies on python.</li>\n<li>Just one script to issue, renew and install your certificates automatically.</li>\n<li>DOES NOT require <code class=\"notranslate\">root/sudoer</code> access.</li>\n<li>Docker ready</li>\n<li>IPv6 ready</li>\n<li>Cron job notifications for renewal or error etc.</li>\n</ul>\n<p dir=\"auto\">It's probably the <code class=\"notranslate\">easiest &amp; smartest</code> shell script to automatically issue &amp; renew the free certificates.</p>\n<p dir=\"auto\">Wiki: <a href=\"https://github.com/acmesh-official/acme.sh/wiki\">https://github.com/acmesh-official/acme.sh/wiki</a></p>\n<p dir=\"auto\">For Docker Fans: <a href=\"https://github.com/acmesh-official/acme.sh/wiki/Run-acme.sh-in-docker\">acme.sh 💕 Docker </a></p>\n<p dir=\"auto\">Twitter: <a href=\"https://twitter.com/neilpangxa\" rel=\"nofollow\">@neilpangxa</a></p>\n<h1 dir=\"auto\"><a href=\"https://github.com/acmesh-official/acme.sh/wiki/%E8%AF%B4%E6%98%8E\">中文说明</a></h1>\n<h1 dir=\"auto\">Who:</h1>\n<ul dir=\"auto\">\n<li><a href=\"https://blog.crashed.org/letsencrypt-in-freebsd-org/\" rel=\"nofollow\">FreeBSD.org</a></li>\n<li><a href=\"https://ruby-china.org/topics/31983\" rel=\"nofollow\">ruby-china.org</a></li>\n<li><a href=\"https://pve.proxmox.com/wiki/Certificate_Management\" rel=\"nofollow\">Proxmox</a></li>\n<li><a href=\"https://github.com/pfsense/FreeBSD-ports/pull/89\" data-hovercard-type=\"pull_request\" data-hovercard-url=\"/pfsense/FreeBSD-ports/pull/89/hovercard\">pfsense</a></li>\n<li><a href=\"https://www.loadbalancer.org/blog/loadbalancer-org-with-lets-encrypt-quick-and-dirty\" rel=\"nofollow\">Loadbalancer.org</a></li>\n<li><a href=\"https://meta.discourse.org/t/setting-up-lets-encrypt/40709\" rel=\"nofollow\">discourse.org</a></li>\n<li><a href=\"https://centminmod.com/letsencrypt-acmetool-https.html\" rel=\"nofollow\">Centminmod</a></li>\n<li><a href=\"https://forum.splynx.com/t/free-ssl-cert-for-splynx-lets-encrypt/297\" rel=\"nofollow\">splynx</a></li>\n<li><a href=\"https://github.com/opnsense/plugins/tree/master/security/acme-client/src/opnsense/scripts/OPNsense/AcmeClient\">opnsense.org</a></li>\n<li><a href=\"https://control-webpanel.com\" rel=\"nofollow\">CentOS Web Panel</a></li>\n<li><a href=\"https://lnmp.org/\" rel=\"nofollow\">lnmp.org</a></li>\n<li><a href=\"https://github.com/acmesh-official/acme.sh/wiki/Blogs-and-tutorials\">more...</a></li>\n</ul>\n<h1 dir=\"auto\">Tested OS</h1>\n<markdown-accessiblity-table><table role=\"table\">\n<thead>\n<tr>\n<th>NO</th>\n<th>Status</th>\n<th>Platform</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>1</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/MacOS.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/MacOS.yml/badge.svg\" alt=\"MacOS\" style=\"max-width: 100%;\"></a></td>\n<td>Mac OSX</td>\n</tr>\n<tr>\n<td>2</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Windows.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Windows.yml/badge.svg\" alt=\"Windows\" style=\"max-width: 100%;\"></a></td>\n<td>Windows (cygwin with curl, openssl and crontab included)</td>\n</tr>\n<tr>\n<td>3</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/FreeBSD.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/FreeBSD.yml/badge.svg\" alt=\"FreeBSD\" style=\"max-width: 100%;\"></a></td>\n<td>FreeBSD</td>\n</tr>\n<tr>\n<td>4</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Solaris.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Solaris.yml/badge.svg\" alt=\"Solaris\" style=\"max-width: 100%;\"></a></td>\n<td>Solaris</td>\n</tr>\n<tr>\n<td>5</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Ubuntu.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Ubuntu.yml/badge.svg\" alt=\"Ubuntu\" style=\"max-width: 100%;\"></a></td>\n<td>Ubuntu</td>\n</tr>\n<tr>\n<td>6</td>\n<td>NA</td>\n<td>pfsense</td>\n</tr>\n<tr>\n<td>7</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/OpenBSD.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/OpenBSD.yml/badge.svg\" alt=\"OpenBSD\" style=\"max-width: 100%;\"></a></td>\n<td>OpenBSD</td>\n</tr>\n<tr>\n<td>8</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/NetBSD.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/NetBSD.yml/badge.svg\" alt=\"NetBSD\" style=\"max-width: 100%;\"></a></td>\n<td>NetBSD</td>\n</tr>\n<tr>\n<td>9</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/DragonFlyBSD.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/DragonFlyBSD.yml/badge.svg\" alt=\"DragonFlyBSD\" style=\"max-width: 100%;\"></a></td>\n<td>DragonFlyBSD</td>\n</tr>\n<tr>\n<td>10</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Omnios.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Omnios.yml/badge.svg\" alt=\"Omnios\" style=\"max-width: 100%;\"></a></td>\n<td>Omnios</td>\n</tr>\n<tr>\n<td>11</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml/badge.svg\" alt=\"Linux\" style=\"max-width: 100%;\"></a></td>\n<td>Debian</td>\n</tr>\n<tr>\n<td>12</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml/badge.svg\" alt=\"Linux\" style=\"max-width: 100%;\"></a></td>\n<td>CentOS</td>\n</tr>\n<tr>\n<td>13</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml/badge.svg\" alt=\"Linux\" style=\"max-width: 100%;\"></a></td>\n<td>openSUSE</td>\n</tr>\n<tr>\n<td>14</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml/badge.svg\" alt=\"Linux\" style=\"max-width: 100%;\"></a></td>\n<td>Alpine Linux (with curl)</td>\n</tr>\n<tr>\n<td>15</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml/badge.svg\" alt=\"Linux\" style=\"max-width: 100%;\"></a></td>\n<td>Archlinux</td>\n</tr>\n<tr>\n<td>16</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml/badge.svg\" alt=\"Linux\" style=\"max-width: 100%;\"></a></td>\n<td>fedora</td>\n</tr>\n<tr>\n<td>17</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml/badge.svg\" alt=\"Linux\" style=\"max-width: 100%;\"></a></td>\n<td>Kali Linux</td>\n</tr>\n<tr>\n<td>18</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml/badge.svg\" alt=\"Linux\" style=\"max-width: 100%;\"></a></td>\n<td>Oracle Linux</td>\n</tr>\n<tr>\n<td>19</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml/badge.svg\" alt=\"Linux\" style=\"max-width: 100%;\"></a></td>\n<td>Mageia</td>\n</tr>\n<tr>\n<td>10</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml/badge.svg\" alt=\"Linux\" style=\"max-width: 100%;\"></a></td>\n<td>Gentoo Linux</td>\n</tr>\n<tr>\n<td>11</td>\n<td><a href=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml\"><img src=\"https://github.com/acmesh-official/acme.sh/actions/workflows/Linux.yml/badge.svg\" alt=\"Linux\" style=\"max-width: 100%;\"></a></td>\n<td>ClearLinux</td>\n</tr>\n<tr>\n<td>22</td>\n<td>-----</td>\n<td>Cloud Linux  <a class=\"issue-link js-issue-link\" data-error-text=\"Failed to load title\" data-id=\"144289669\" data-permission-text=\"Title is private\" data-url=\"https://github.com/acmesh-official/acme.sh/issues/111\" data-hovercard-type=\"issue\" data-hovercard-url=\"/acmesh-official/acme.sh/issues/111/hovercard\" href=\"https://github.com/acmesh-official/acme.sh/issues/111\">acmesh-official/acme.sh#111</a></td>\n</tr>\n<tr>\n<td>23</td>\n<td>-----</td>\n<td>OpenWRT: Tested and working. See <a href=\"https://github.com/acmesh-official/acme.sh/wiki/How-to-run-on-OpenWRT\">wiki page</a></td>\n</tr>\n<tr>\n<td>24</td>\n<td><a href=\"https://github.com/acmesh-official/letest#here-are-the-latest-status\"><img src=\"https://camo.githubusercontent.com/5cfefd7e3c348b1666c53d95035494cd478be32b94a4b3e5a388c779977a0c01/68747470733a2f2f61636d6573682d6f6666696369616c2e6769746875622e696f2f61636d65746573742f7374617475732f70726f786d6f782e737667\" alt=\"\" data-canonical-src=\"https://acmesh-official.github.io/acmetest/status/proxmox.svg\" style=\"max-width: 100%;\"></a></td>\n<td>Proxmox: See Proxmox VE Wiki. Version <a href=\"https://pve.proxmox.com/wiki/HTTPS_Certificate_Configuration_(Version_4.x,_5.0_and_5.1)#Let.27s_Encrypt_using_acme.sh\" rel=\"nofollow\">4.x, 5.0, 5.1</a>, version <a href=\"https://pve.proxmox.com/wiki/Certificate_Management\" rel=\"nofollow\">5.2 and up</a></td>\n</tr>\n</tbody>\n</table></markdown-accessiblity-table>\n<p dir=\"auto\">Check our <a href=\"https://github.com/acmesh-official/acmetest\">testing project</a>:</p>\n<p dir=\"auto\"><a href=\"https://github.com/acmesh-official/acmetest\">https://github.com/acmesh-official/acmetest</a></p>\n<h1 dir=\"auto\">Supported CA</h1>\n<ul dir=\"auto\">\n<li><a href=\"https://github.com/acmesh-official/acme.sh/wiki/ZeroSSL.com-CA\">ZeroSSL.com CA</a>(default)</li>\n<li>Letsencrypt.org CA</li>\n<li><a href=\"https://github.com/acmesh-official/acme.sh/wiki/BuyPass.com-CA\">BuyPass.com CA</a></li>\n<li><a href=\"https://github.com/acmesh-official/acme.sh/wiki/SSL.com-CA\">SSL.com CA</a></li>\n<li><a href=\"https://github.com/acmesh-official/acme.sh/wiki/Google-Public-CA\">Google.com Public CA</a></li>\n<li><a href=\"https://github.com/letsencrypt/pebble\">Pebble strict Mode</a></li>\n<li>Any other <a href=\"https://tools.ietf.org/html/rfc8555\" rel=\"nofollow\">RFC8555</a>-compliant CA</li>\n</ul>\n<h1 dir=\"auto\">Supported modes</h1>\n<ul dir=\"auto\">\n<li>Webroot mode</li>\n<li>Standalone mode</li>\n<li>Standalone tls-alpn mode</li>\n<li>Apache mode</li>\n<li>Nginx mode</li>\n<li>DNS mode</li>\n<li><a href=\"https://github.com/acmesh-official/acme.sh/wiki/DNS-alias-mode\">DNS alias mode</a></li>\n<li><a href=\"https://github.com/acmesh-official/acme.sh/wiki/Stateless-Mode\">Stateless mode</a></li>\n</ul>\n<h1 dir=\"auto\">1. How to install</h1>\n<h3 dir=\"auto\">1. Install online</h3>\n<p dir=\"auto\">Check this project: <a href=\"https://github.com/acmesh-official/get.acme.sh\">https://github.com/acmesh-official/get.acme.sh</a></p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"curl https://get.acme.sh | sh -s email=my@example.com\"><pre class=\"notranslate\">curl https://get.acme.sh <span class=\"pl-k\">|</span> sh -s email=my@example.com</pre></div>\n<p dir=\"auto\">Or:</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"wget -O -  https://get.acme.sh | sh -s email=my@example.com\"><pre class=\"notranslate\">wget -O -  https://get.acme.sh <span class=\"pl-k\">|</span> sh -s email=my@example.com</pre></div>\n<h3 dir=\"auto\">2. Or, Install from git</h3>\n<p dir=\"auto\">Clone this project and launch installation:</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"git clone https://github.com/acmesh-official/acme.sh.git\ncd ./acme.sh\n./acme.sh --install -m my@example.com\"><pre class=\"notranslate\">git clone https://github.com/acmesh-official/acme.sh.git\n<span class=\"pl-c1\">cd</span> ./acme.sh\n./acme.sh --install -m my@example.com</pre></div>\n<p dir=\"auto\">You <code class=\"notranslate\">don't have to be root</code> then, although <code class=\"notranslate\">it is recommended</code>.</p>\n<p dir=\"auto\">Advanced Installation: <a href=\"https://github.com/acmesh-official/acme.sh/wiki/How-to-install\">https://github.com/acmesh-official/acme.sh/wiki/How-to-install</a></p>\n<p dir=\"auto\">The installer will perform 3 actions:</p>\n<ol dir=\"auto\">\n<li>Create and copy <code class=\"notranslate\">acme.sh</code> to your home dir (<code class=\"notranslate\">$HOME</code>): <code class=\"notranslate\">~/.acme.sh/</code>.<br>\nAll certs will be placed in this folder too.</li>\n<li>Create alias for: <code class=\"notranslate\">acme.sh=~/.acme.sh/acme.sh</code>.</li>\n<li>Create daily cron job to check and renew the certs if needed.</li>\n</ol>\n<p dir=\"auto\">Cron entry example:</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"0 0 * * * &quot;/home/user/.acme.sh&quot;/acme.sh --cron --home &quot;/home/user/.acme.sh&quot; &gt; /dev/null\"><pre class=\"notranslate\">0 0 <span class=\"pl-k\">*</span> <span class=\"pl-k\">*</span> <span class=\"pl-k\">*</span> <span class=\"pl-s\"><span class=\"pl-pds\">\"</span>/home/user/.acme.sh<span class=\"pl-pds\">\"</span></span>/acme.sh --cron --home <span class=\"pl-s\"><span class=\"pl-pds\">\"</span>/home/user/.acme.sh<span class=\"pl-pds\">\"</span></span> <span class=\"pl-k\">&gt;</span> /dev/null</pre></div>\n<p dir=\"auto\">After the installation, you must close the current terminal and reopen it to make the alias take effect.</p>\n<p dir=\"auto\">Ok, you are ready to issue certs now.</p>\n<p dir=\"auto\">Show help message:</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"root@v1:~# acme.sh -h\"><pre class=\"notranslate\">root@v1:<span class=\"pl-k\">~</span><span class=\"pl-c\"><span class=\"pl-c\">#</span> acme.sh -h</span></pre></div>\n<h1 dir=\"auto\">2. Just issue a cert</h1>\n<p dir=\"auto\"><strong>Example 1:</strong> Single domain.</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --issue -d example.com -w /home/wwwroot/example.com\"><pre class=\"notranslate\">acme.sh --issue -d example.com -w /home/wwwroot/example.com</pre></div>\n<p dir=\"auto\">or:</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --issue -d example.com -w /home/username/public_html\"><pre class=\"notranslate\">acme.sh --issue -d example.com -w /home/username/public_html</pre></div>\n<p dir=\"auto\">or:</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --issue -d example.com -w /var/www/html\"><pre class=\"notranslate\">acme.sh --issue -d example.com -w /var/www/html</pre></div>\n<p dir=\"auto\"><strong>Example 2:</strong> Multiple domains in the same cert.</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --issue -d example.com -d www.example.com -d cp.example.com -w /home/wwwroot/example.com\"><pre class=\"notranslate\">acme.sh --issue -d example.com -d www.example.com -d cp.example.com -w /home/wwwroot/example.com</pre></div>\n<p dir=\"auto\">The parameter <code class=\"notranslate\">/home/wwwroot/example.com</code> or <code class=\"notranslate\">/home/username/public_html</code> or <code class=\"notranslate\">/var/www/html</code> is the web root folder where you host your website files. You <strong>MUST</strong> have <code class=\"notranslate\">write access</code> to this folder.</p>\n<p dir=\"auto\">Second argument <strong>\"example.com\"</strong> is the main domain you want to issue the cert for.<br>\nYou must have at least one domain there.</p>\n<p dir=\"auto\">You must point and bind all the domains to the same webroot dir: <code class=\"notranslate\">/home/wwwroot/example.com</code>.</p>\n<p dir=\"auto\">The certs will be placed in <code class=\"notranslate\">~/.acme.sh/example.com/</code></p>\n<p dir=\"auto\">The certs will be renewed automatically every <strong>60</strong> days.</p>\n<p dir=\"auto\">More examples: <a href=\"https://github.com/acmesh-official/acme.sh/wiki/How-to-issue-a-cert\">https://github.com/acmesh-official/acme.sh/wiki/How-to-issue-a-cert</a></p>\n<h1 dir=\"auto\">3. Install the cert to Apache/Nginx etc.</h1>\n<p dir=\"auto\">After the cert is generated, you probably want to install/copy the cert to your Apache/Nginx or other servers.<br>\nYou <strong>MUST</strong> use this command to copy the certs to the target files, <strong>DO NOT</strong> use the certs files in <strong>~/.acme.sh/</strong> folder, they are for internal use only, the folder structure may change in the future.</p>\n<p dir=\"auto\"><strong>Apache</strong> example:</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --install-cert -d example.com \\\n--cert-file      /path/to/certfile/in/apache/cert.pem  \\\n--key-file       /path/to/keyfile/in/apache/key.pem  \\\n--fullchain-file /path/to/fullchain/certfile/apache/fullchain.pem \\\n--reloadcmd     &quot;service apache2 force-reload&quot;\"><pre class=\"notranslate\">acme.sh --install-cert -d example.com \\\n--cert-file      /path/to/certfile/in/apache/cert.pem  \\\n--key-file       /path/to/keyfile/in/apache/key.pem  \\\n--fullchain-file /path/to/fullchain/certfile/apache/fullchain.pem \\\n--reloadcmd     <span class=\"pl-s\"><span class=\"pl-pds\">\"</span>service apache2 force-reload<span class=\"pl-pds\">\"</span></span></pre></div>\n<p dir=\"auto\"><strong>Nginx</strong> example:</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --install-cert -d example.com \\\n--key-file       /path/to/keyfile/in/nginx/key.pem  \\\n--fullchain-file /path/to/fullchain/nginx/cert.pem \\\n--reloadcmd     &quot;service nginx force-reload&quot;\"><pre class=\"notranslate\">acme.sh --install-cert -d example.com \\\n--key-file       /path/to/keyfile/in/nginx/key.pem  \\\n--fullchain-file /path/to/fullchain/nginx/cert.pem \\\n--reloadcmd     <span class=\"pl-s\"><span class=\"pl-pds\">\"</span>service nginx force-reload<span class=\"pl-pds\">\"</span></span></pre></div>\n<p dir=\"auto\">Only the domain is required, all the other parameters are optional.</p>\n<p dir=\"auto\">The ownership and permission info of existing files are preserved. You can pre-create the files to define the ownership and permission.</p>\n<p dir=\"auto\">Install/copy the cert/key to the production Apache or Nginx path.</p>\n<p dir=\"auto\">The cert will be renewed every <strong>60</strong> days by default (which is configurable). Once the cert is renewed, the Apache/Nginx service will be reloaded automatically by the command: <code class=\"notranslate\">service apache2 force-reload</code> or <code class=\"notranslate\">service nginx force-reload</code>.</p>\n<p dir=\"auto\"><strong>Please take care:  The reloadcmd is very important. The cert can be automatically renewed, but, without a correct 'reloadcmd' the cert may not be flushed to your server(like nginx or apache), then your website will not be able to show renewed cert in 60 days.</strong></p>\n<h1 dir=\"auto\">4. Use Standalone server to issue cert</h1>\n<p dir=\"auto\"><strong>(requires you to be root/sudoer or have permission to listen on port 80 (TCP))</strong></p>\n<p dir=\"auto\">Port <code class=\"notranslate\">80</code> (TCP) <strong>MUST</strong> be free to listen on, otherwise you will be prompted to free it and try again.</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --issue --standalone -d example.com -d www.example.com -d cp.example.com\"><pre class=\"notranslate\">acme.sh --issue --standalone -d example.com -d www.example.com -d cp.example.com</pre></div>\n<p dir=\"auto\">More examples: <a href=\"https://github.com/acmesh-official/acme.sh/wiki/How-to-issue-a-cert\">https://github.com/acmesh-official/acme.sh/wiki/How-to-issue-a-cert</a></p>\n<h1 dir=\"auto\">5. Use Standalone ssl server to issue cert</h1>\n<p dir=\"auto\"><strong>(requires you to be root/sudoer or have permission to listen on port 443 (TCP))</strong></p>\n<p dir=\"auto\">Port <code class=\"notranslate\">443</code> (TCP) <strong>MUST</strong> be free to listen on, otherwise you will be prompted to free it and try again.</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --issue --alpn -d example.com -d www.example.com -d cp.example.com\"><pre class=\"notranslate\">acme.sh --issue --alpn -d example.com -d www.example.com -d cp.example.com</pre></div>\n<p dir=\"auto\">More examples: <a href=\"https://github.com/acmesh-official/acme.sh/wiki/How-to-issue-a-cert\">https://github.com/acmesh-official/acme.sh/wiki/How-to-issue-a-cert</a></p>\n<h1 dir=\"auto\">6. Use Apache mode</h1>\n<p dir=\"auto\"><strong>(requires you to be root/sudoer, since it is required to interact with Apache server)</strong></p>\n<p dir=\"auto\">If you are running a web server, it is recommended to use the <code class=\"notranslate\">Webroot mode</code>.</p>\n<p dir=\"auto\">Particularly, if you are running an Apache server, you can use Apache mode instead. This mode doesn't write any files to your web root folder.</p>\n<p dir=\"auto\">Just set string \"apache\" as the second argument and it will force use of apache plugin automatically.</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --issue --apache -d example.com -d www.example.com -d cp.example.com\"><pre class=\"notranslate\">acme.sh --issue --apache -d example.com -d www.example.com -d cp.example.com</pre></div>\n<p dir=\"auto\"><strong>This apache mode is only to issue the cert, it will not change your apache config files.<br>\nYou will need to configure your website config files to use the cert by yourself.<br>\nWe don't want to mess with your apache server, don't worry.</strong></p>\n<p dir=\"auto\">More examples: <a href=\"https://github.com/acmesh-official/acme.sh/wiki/How-to-issue-a-cert\">https://github.com/acmesh-official/acme.sh/wiki/How-to-issue-a-cert</a></p>\n<h1 dir=\"auto\">7. Use Nginx mode</h1>\n<p dir=\"auto\"><strong>(requires you to be root/sudoer, since it is required to interact with Nginx server)</strong></p>\n<p dir=\"auto\">If you are running a web server, it is recommended to use the <code class=\"notranslate\">Webroot mode</code>.</p>\n<p dir=\"auto\">Particularly, if you are running an nginx server, you can use nginx mode instead. This mode doesn't write any files to your web root folder.</p>\n<p dir=\"auto\">Just set string \"nginx\" as the second argument.</p>\n<p dir=\"auto\">It will configure nginx server automatically to verify the domain and then restore the nginx config to the original version.</p>\n<p dir=\"auto\">So, the config is not changed.</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --issue --nginx -d example.com -d www.example.com -d cp.example.com\"><pre class=\"notranslate\">acme.sh --issue --nginx -d example.com -d www.example.com -d cp.example.com</pre></div>\n<p dir=\"auto\"><strong>This nginx mode is only to issue the cert, it will not change your nginx config files.<br>\nYou will need to configure your website config files to use the cert by yourself.<br>\nWe don't want to mess with your nginx server, don't worry.</strong></p>\n<p dir=\"auto\">More examples: <a href=\"https://github.com/acmesh-official/acme.sh/wiki/How-to-issue-a-cert\">https://github.com/acmesh-official/acme.sh/wiki/How-to-issue-a-cert</a></p>\n<h1 dir=\"auto\">8. Automatic DNS API integration</h1>\n<p dir=\"auto\">If your DNS provider supports API access, we can use that API to automatically issue the certs.</p>\n<p dir=\"auto\">You don't have to do anything manually!</p>\n<h3 dir=\"auto\">Currently acme.sh supports most of the dns providers:</h3>\n<p dir=\"auto\"><a href=\"https://github.com/acmesh-official/acme.sh/wiki/dnsapi\">https://github.com/acmesh-official/acme.sh/wiki/dnsapi</a></p>\n<h1 dir=\"auto\">9. Use DNS manual mode:</h1>\n<p dir=\"auto\">See: <a href=\"https://github.com/acmesh-official/acme.sh/wiki/dns-manual-mode\">https://github.com/acmesh-official/acme.sh/wiki/dns-manual-mode</a> first.</p>\n<p dir=\"auto\">If your dns provider doesn't support any api access, you can add the txt record by hand.</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --issue --dns -d example.com -d www.example.com -d cp.example.com\"><pre class=\"notranslate\">acme.sh --issue --dns -d example.com -d www.example.com -d cp.example.com</pre></div>\n<p dir=\"auto\">You should get an output like below:</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"Add the following txt record:\nDomain:_acme-challenge.example.com\nTxt value:9ihDbjYfTExAYeDs4DBUeuTo18KBzwvTEjUnSwd32-c\n\nAdd the following txt record:\nDomain:_acme-challenge.www.example.com\nTxt value:9ihDbjxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx\n\nPlease add those txt records to the domains. Waiting for the dns to take effect.\"><pre class=\"notranslate\">Add the following txt record:\nDomain:_acme-challenge.example.com\nTxt value:9ihDbjYfTExAYeDs4DBUeuTo18KBzwvTEjUnSwd32-c\n\nAdd the following txt record:\nDomain:_acme-challenge.www.example.com\nTxt value:9ihDbjxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx\n\nPlease add those txt records to the domains. Waiting <span class=\"pl-k\">for</span> the dns to take effect.</pre></div>\n<p dir=\"auto\">Then just rerun with <code class=\"notranslate\">renew</code> argument:</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --renew -d example.com\"><pre class=\"notranslate\">acme.sh --renew -d example.com</pre></div>\n<p dir=\"auto\">Ok, it's done.</p>\n<p dir=\"auto\"><strong>Take care, this is dns manual mode, it can not be renewed automatically. you will have to add a new txt record to your domain by your hand when you renew your cert.</strong></p>\n<p dir=\"auto\"><strong>Please use dns api mode instead.</strong></p>\n<h1 dir=\"auto\">10. Issue ECC certificates</h1>\n<p dir=\"auto\">Just set the <code class=\"notranslate\">keylength</code> parameter with a prefix <code class=\"notranslate\">ec-</code>.</p>\n<p dir=\"auto\">For example:</p>\n<h3 dir=\"auto\">Single domain ECC certificate</h3>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --issue -w /home/wwwroot/example.com -d example.com --keylength ec-256\"><pre class=\"notranslate\">acme.sh --issue -w /home/wwwroot/example.com -d example.com --keylength ec-256</pre></div>\n<h3 dir=\"auto\">SAN multi domain ECC certificate</h3>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --issue -w /home/wwwroot/example.com -d example.com -d www.example.com --keylength ec-256\"><pre class=\"notranslate\">acme.sh --issue -w /home/wwwroot/example.com -d example.com -d www.example.com --keylength ec-256</pre></div>\n<p dir=\"auto\">Please look at the <code class=\"notranslate\">keylength</code> parameter above.</p>\n<p dir=\"auto\">Valid values are:</p>\n<ol dir=\"auto\">\n<li><strong>ec-256 (prime256v1, \"ECDSA P-256\", which is the default key type)</strong></li>\n<li><strong>ec-384 (secp384r1,  \"ECDSA P-384\")</strong></li>\n<li><strong>ec-521 (secp521r1,  \"ECDSA P-521\", which is not supported by Let's Encrypt yet.)</strong></li>\n<li><strong>2048   (RSA2048)</strong></li>\n<li><strong>3072   (RSA3072)</strong></li>\n<li><strong>4096   (RSA4096)</strong></li>\n</ol>\n<h1 dir=\"auto\">11. Issue Wildcard certificates</h1>\n<p dir=\"auto\">It's simple, just give a wildcard domain as the <code class=\"notranslate\">-d</code> parameter.</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh  --issue -d example.com  -d '*.example.com'  --dns dns_cf\"><pre class=\"notranslate\">acme.sh  --issue -d example.com  -d <span class=\"pl-s\"><span class=\"pl-pds\">'</span>*.example.com<span class=\"pl-pds\">'</span></span>  --dns dns_cf</pre></div>\n<h1 dir=\"auto\">12. How to renew the certs</h1>\n<p dir=\"auto\">No, you don't need to renew the certs manually. All the certs will be renewed automatically every <strong>60</strong> days.</p>\n<p dir=\"auto\">However, you can also force to renew a cert:</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --renew -d example.com --force\"><pre class=\"notranslate\">acme.sh --renew -d example.com --force</pre></div>\n<p dir=\"auto\">or, for ECC cert:</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --renew -d example.com --force --ecc\"><pre class=\"notranslate\">acme.sh --renew -d example.com --force --ecc</pre></div>\n<h1 dir=\"auto\">13. How to stop cert renewal</h1>\n<p dir=\"auto\">To stop renewal of a cert, you can execute the following to remove the cert from the renewal list:</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --remove -d example.com [--ecc]\"><pre class=\"notranslate\">acme.sh --remove -d example.com [--ecc]</pre></div>\n<p dir=\"auto\">The cert/key file is not removed from the disk.</p>\n<p dir=\"auto\">You can remove the respective directory (e.g. <code class=\"notranslate\">~/.acme.sh/example.com</code>) by yourself.</p>\n<h1 dir=\"auto\">14. How to upgrade <code class=\"notranslate\">acme.sh</code></h1>\n<p dir=\"auto\">acme.sh is in constant development, so it's strongly recommended to use the latest code.</p>\n<p dir=\"auto\">You can update acme.sh to the latest code:</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --upgrade\"><pre class=\"notranslate\">acme.sh --upgrade</pre></div>\n<p dir=\"auto\">You can also enable auto upgrade:</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --upgrade --auto-upgrade\"><pre class=\"notranslate\">acme.sh --upgrade --auto-upgrade</pre></div>\n<p dir=\"auto\">Then <strong>acme.sh</strong> will be kept up to date automatically.</p>\n<p dir=\"auto\">Disable auto upgrade:</p>\n<div class=\"highlight highlight-source-shell notranslate position-relative overflow-auto\" dir=\"auto\" data-snippet-clipboard-copy-content=\"acme.sh --upgrade --auto-upgrade 0\"><pre class=\"notranslate\">acme.sh --upgrade --auto-upgrade 0</pre></div>\n<h1 dir=\"auto\">15. Issue a cert from an existing CSR</h1>\n<p dir=\"auto\"><a href=\"https://github.com/acmesh-official/acme.sh/wiki/Issue-a-cert-from-existing-CSR\">https://github.com/acmesh-official/acme.sh/wiki/Issue-a-cert-from-existing-CSR</a></p>\n<h1 dir=\"auto\">16. Send notifications in cronjob</h1>\n<p dir=\"auto\"><a href=\"https://github.com/acmesh-official/acme.sh/wiki/notify\">https://github.com/acmesh-official/acme.sh/wiki/notify</a></p>\n<h1 dir=\"auto\">17. Under the Hood</h1>\n<p dir=\"auto\">Speak ACME language using shell, directly to \"Let's Encrypt\".</p>\n<p dir=\"auto\">TODO:</p>\n<h1 dir=\"auto\">18. Acknowledgments</h1>\n<ol dir=\"auto\">\n<li>Acme-tiny: <a href=\"https://github.com/diafygi/acme-tiny\">https://github.com/diafygi/acme-tiny</a></li>\n<li>ACME protocol: <a href=\"https://github.com/ietf-wg-acme/acme\">https://github.com/ietf-wg-acme/acme</a></li>\n</ol>\n<h2 dir=\"auto\">Contributors</h2>\n<h3 dir=\"auto\">Code Contributors</h3>\n<p dir=\"auto\">This project exists thanks to all the people who contribute.<br>\n<a href=\"https://github.com/acmesh-official/acme.sh/graphs/contributors\"><img src=\"https://camo.githubusercontent.com/1fb970f7a8518dee24ff87f5aea0090b7990573f85cc7179a8d2ccece15aa31a/68747470733a2f2f6f70656e636f6c6c6563746976652e636f6d2f61636d6573682f636f6e7472696275746f72732e7376673f77696474683d38393026627574746f6e3d66616c7365\" data-canonical-src=\"https://opencollective.com/acmesh/contributors.svg?width=890&amp;button=false\" style=\"max-width: 100%;\"></a></p>\n<h3 dir=\"auto\">Financial Contributors</h3>\n<p dir=\"auto\">Become a financial contributor and help us sustain our community. [<a href=\"https://opencollective.com/acmesh/contribute\" rel=\"nofollow\">Contribute</a>]</p>\n<h4 dir=\"auto\">Individuals</h4>\n<p dir=\"auto\"><a href=\"https://opencollective.com/acmesh\" rel=\"nofollow\"><img src=\"https://camo.githubusercontent.com/05a50bae1ef1d63fe5b7c80d6d1f2debe638dc4d0dd53cf7fdcfa9889b7cb3b4/68747470733a2f2f6f70656e636f6c6c6563746976652e636f6d2f61636d6573682f696e646976696475616c732e7376673f77696474683d383930\" data-canonical-src=\"https://opencollective.com/acmesh/individuals.svg?width=890\" style=\"max-width: 100%;\"></a></p>\n<h4 dir=\"auto\">Organizations</h4>\n<p dir=\"auto\">Support this project with your organization. Your logo will show up here with a link to your website. [<a href=\"https://opencollective.com/acmesh/contribute\" rel=\"nofollow\">Contribute</a>]</p>\n<p dir=\"auto\"><a href=\"https://opencollective.com/acmesh/organization/0/website\" rel=\"nofollow\"><img src=\"https://camo.githubusercontent.com/7f3e9738c22ef062419b6bd8fbf7b5010e17599dc82283441040f3b92e8029f5/68747470733a2f2f6f70656e636f6c6c6563746976652e636f6d2f61636d6573682f6f7267616e697a6174696f6e2f302f6176617461722e737667\" data-canonical-src=\"https://opencollective.com/acmesh/organization/0/avatar.svg\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://opencollective.com/acmesh/organization/1/website\" rel=\"nofollow\"><img src=\"https://camo.githubusercontent.com/231622d3cdfe46905740a942f43e3feab77b4da13b8a617f30bdf9166128ad81/68747470733a2f2f6f70656e636f6c6c6563746976652e636f6d2f61636d6573682f6f7267616e697a6174696f6e2f312f6176617461722e737667\" data-canonical-src=\"https://opencollective.com/acmesh/organization/1/avatar.svg\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://opencollective.com/acmesh/organization/2/website\" rel=\"nofollow\"><img src=\"https://camo.githubusercontent.com/a0c016e549f9430437f5ce70ad4122661870da8d0a5ce2e2cc302b14ee2748bb/68747470733a2f2f6f70656e636f6c6c6563746976652e636f6d2f61636d6573682f6f7267616e697a6174696f6e2f322f6176617461722e737667\" data-canonical-src=\"https://opencollective.com/acmesh/organization/2/avatar.svg\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://opencollective.com/acmesh/organization/3/website\" rel=\"nofollow\"><img src=\"https://camo.githubusercontent.com/6ad10f9ac1710f2489e283c13386a14fe6054dcb84bc576137a6d83f674cda1e/68747470733a2f2f6f70656e636f6c6c6563746976652e636f6d2f61636d6573682f6f7267616e697a6174696f6e2f332f6176617461722e737667\" data-canonical-src=\"https://opencollective.com/acmesh/organization/3/avatar.svg\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://opencollective.com/acmesh/organization/4/website\" rel=\"nofollow\"><img src=\"https://camo.githubusercontent.com/f1687f0789082b5ec90e5c21076144877304047a25ecaa97d2d2a5ed86113331/68747470733a2f2f6f70656e636f6c6c6563746976652e636f6d2f61636d6573682f6f7267616e697a6174696f6e2f342f6176617461722e737667\" data-canonical-src=\"https://opencollective.com/acmesh/organization/4/avatar.svg\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://opencollective.com/acmesh/organization/5/website\" rel=\"nofollow\"><img src=\"https://camo.githubusercontent.com/d663f06569c6468a8a4396d5c9732ec8336517b3247e6101637aa6dfcc8c3c90/68747470733a2f2f6f70656e636f6c6c6563746976652e636f6d2f61636d6573682f6f7267616e697a6174696f6e2f352f6176617461722e737667\" data-canonical-src=\"https://opencollective.com/acmesh/organization/5/avatar.svg\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://opencollective.com/acmesh/organization/6/website\" rel=\"nofollow\"><img src=\"https://camo.githubusercontent.com/46c6c7829d50c560b4db98c21d2fe620683fb5d61bdf9858dc499e54ebbea179/68747470733a2f2f6f70656e636f6c6c6563746976652e636f6d2f61636d6573682f6f7267616e697a6174696f6e2f362f6176617461722e737667\" data-canonical-src=\"https://opencollective.com/acmesh/organization/6/avatar.svg\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://opencollective.com/acmesh/organization/7/website\" rel=\"nofollow\"><img src=\"https://camo.githubusercontent.com/32b9697292fe3c59aa7382b8001cf4ba751e24d35395e5768960b7fed77f007f/68747470733a2f2f6f70656e636f6c6c6563746976652e636f6d2f61636d6573682f6f7267616e697a6174696f6e2f372f6176617461722e737667\" data-canonical-src=\"https://opencollective.com/acmesh/organization/7/avatar.svg\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://opencollective.com/acmesh/organization/8/website\" rel=\"nofollow\"><img src=\"https://camo.githubusercontent.com/94339c3486e43a60fd409bd5b22287e461c1d3826b118bae6375364357711b50/68747470733a2f2f6f70656e636f6c6c6563746976652e636f6d2f61636d6573682f6f7267616e697a6174696f6e2f382f6176617461722e737667\" data-canonical-src=\"https://opencollective.com/acmesh/organization/8/avatar.svg\" style=\"max-width: 100%;\"></a><br>\n<a href=\"https://opencollective.com/acmesh/organization/9/website\" rel=\"nofollow\"><img src=\"https://camo.githubusercontent.com/d41b3fc26df306203160f2136dd327be87490ce6f7c97753f81c9ce5c27fcab1/68747470733a2f2f6f70656e636f6c6c6563746976652e636f6d2f61636d6573682f6f7267616e697a6174696f6e2f392f6176617461722e737667\" data-canonical-src=\"https://opencollective.com/acmesh/organization/9/avatar.svg\" style=\"max-width: 100%;\"></a></p>\n<h1 dir=\"auto\">19. License &amp; Others</h1>\n<p dir=\"auto\">License is GPLv3</p>\n<p dir=\"auto\">Please Star and Fork me.</p>\n<p dir=\"auto\"><a href=\"https://github.com/acmesh-official/acme.sh/issues\">Issues</a> and <a href=\"https://github.com/acmesh-official/acme.sh/pulls\">pull requests</a> are welcome.</p>\n<h1 dir=\"auto\">20. Donate</h1>\n<p dir=\"auto\">Your donation makes <strong>acme.sh</strong> better:</p>\n<ol dir=\"auto\">\n<li>PayPal/Alipay(支付宝)/Wechat(微信): <a href=\"https://donate.acme.sh/\" rel=\"nofollow\">https://donate.acme.sh/</a></li>\n</ol>\n<p dir=\"auto\"><a href=\"https://github.com/acmesh-official/acme.sh/wiki/Donate-list\">Donate List</a></p>","updatedAt":"2025-05-21T15:47:36Z","upvoteCount":null,"author":{"login":"eryajf","avatarUrl":"https://avatars.githubusercontent.com/u/33259379?u=e4a4090a38ac2473aaed4ef9945233636776c6c3&v=4","url":"https://github.com/eryajf"},"category":null,"labels":{"edges":[{"node":{"name":"更多","color":"25B472"}},{"node":{"name":"证书管理","color":"34a405"}},{"node":{"name":"acmesh-official","color":"5d8693"}}]},"comments":{"edges":[]}}},"pageContext":{"number":8,"previous":{"title":"beyondgrep/ack3: ack 是一个代码搜索工具，类似于 grep，但针对搜索大型源代码树的程序员进行了优化。","number":7},"next":{"title":"nektos/act: 本地运行 GitHub Actions","number":9}}},
    "staticQueryHashes": ["151096407","2861350382"]}