使用 PHP 7 给 Web 应用加速

PHP 20周年了!??

PHP 首发通告,1995年6月8日

发布于 COMP.INFOSYSTEMS.WWW.AUTHORING.CGI


主题:正式宣布:个人主页工具(Personal Home Page Tools)正式宣布个人主页工具(PHP 工具)1.0 版本此工具是一组用 C 语言写的轻量的 cgi 二进制文件。他们能运行许多功能,包括:
  • 在你的私有日志文件记录页面访问情况

  • 实时查看日志信息

  • 提供查看日志信息的友好接口

  • 在你的页面展示最近一次的访问信息

  • 完整的每天及总体访问统计

  • 依据用户的域名限制其访问

  • 依据用户的域名为页面提供密码保护

  • 依据用户的电子邮箱地址追踪其访问情况

  • 支持追踪引荐 URL 的 HTTP_REFERER

  • 无需服务器支持即可运行 SSI (server-side includes)

  • 支持不记录特定域名(比如,你自己的)的访问信息

  • 轻易地创建并展示表格

  • 支持在后续的文档中使用表格信息

    使用该工具,你不需要:

  • 你不需要访问根目录——工具安装在 ~/public_html 目录

  • 你不需要在服务器启用 SSI (server-side includes)

  • 你不需要使用 Perl 或 Tcl 或其他任何脚本解释器

  • 你不需要访问 httpd 日志文件

    使用该工具的唯一条件是你能够运行自己的 cgi 程序。如果你不知道这是什么意思,可以询问系统管理员。

    借助该工具,你还可以在两分钟内实现留言板,或其他任何用于写入信息并向访客展示的表格。

    该工具不受版权限制,遵循 GNU 公共许可证。是的!该工具完全免费!

    查看该工具的完整演示,请访问:http://www.io.org/~rasmus。

    --
    Rasmus Lerdorf
    rasmus@io.org
    http://www.io.org/~rasmus

用于 Web 应用的 C API

void Cos(void) {
Stack *s;
char temp[64];s = Pop();
if(!s) {Error("Stack error in cos");return;
}
sprintf(temp,"%f",cos(s->douval));
Push(temp,DNUMBER);
}

于是乎,你可以这样使用它:

<html><head><title>Cos Example</title></head>
<body><h1>Cos Example</h1>
<?echo Cos($input)>
</body></html>

PHP7

✔ 引擎提升
  • 现实世界中的大多数应用程序都能获得 100% 以上的性能提升

  • 内存使用量更低

  • 原生线程本地储存

✔ 持久的以文件为基础的二级缓存 OPCache

    ; --enable-opcache-file; php.iniopcache.file_cache=/var/tmp; php-cli.iniopcache.enable_cli=1opcache.file_cache=/var/tmpopcache.file_cache_only=1
$ time composer >/dev/nullreal    0m0.040suser    0m0.032ssys    0m0.004s$ time composer >/dev/nullreal    0m0.019suser    0m0.016ssys    0m0.000s$ time php -d opcache.enable=0 /usr/local/bin/composer >/dev/nullreal    0m0.033suser    0m0.032ssys    0m0.000s
    /var/tmp├── 7eeb6fe88104116c27c5650ddd83abf0│   └── usr│      └── local│         └── bin│             └── composer.bin└── 7eeb6fe88104116c27c5650ddd83abf0phar:└── usr└── local└── bin└── composer├── bin│   └── composer.bin├── src│   ├── bootstrap.php.bin│   └── Composer│       ├── Command│       │   ├── AboutCommand.php.bin│       │   ├── ArchiveCommand.php.bin│       │   ├── ClearCacheCommand.php.bin│       │   ├── Command.php.bin│       │   ├── ConfigCommand.php.bin│       │   ├── CreateProjectCommand.php.bin│       │   ├── DependsCommand.php.bin│       │   ├── DiagnoseCommand.php.bin│       │   ├── DumpAutoloadCommand.php.bin│       │   ├── GlobalCommand.php.bin│       │   ├── Helper│       │   │   └── DialogHelper.php.bin│       │   ├── HomeCommand.php.bin│       │   ├── InitCommand.php.bin│       │   ├── InstallCommand.php.bin│       │   ├── LicensesCommand.php.bin│       │   ├── RemoveCommand.php.bin│       │   ├── RequireCommand.php.bin│       │   ├── RunScriptCommand.php.bin│       │   ├── SearchCommand.php.bin│       │   ├── SelfUpdateCommand.php.bin│       │   ├── ShowCommand.php.bin│       │   ├── StatusCommand.php.bin│       │   ├── UpdateCommand.php.bin│       │   └── ValidateCommand.php.bin│       ├── Composer.php.bin│       ├── Console│       │   └── Application.php.bin│       ├── Factory.php.bin│       ├── IO│       │   ├── BaseIO.php.bin│       │   ├── ConsoleIO.php.bin│       │   └── IOInterface.php.bin│       ├── Package│       │   ├── BasePackage.php.bin│       │   └── PackageInterface.php.bin│       ├── Script│       │   └── ScriptEvents.php.bin│       └── Util│           └── ErrorHandler.php.bin└── vendor├── autoload.php.bin├── composer│   ├── autoload_classmap.php.bin│   ├── autoload_namespaces.php.bin│   ├── autoload_psr4.php.bin│   ├── autoload_real.php.bin│   └── ClassLoader.php.bin└── symfony└── console└── Symfony└── Component└── Console├── Application.php.bin├── Command│   ├── Command.php.bin│   ├── HelpCommand.php.bin│   └── ListCommand.php.bin├── Descriptor│   ├── ApplicationDescription.php.bin│   ├── DescriptorInterface.php.bin│   ├── Descriptor.php.bin│   ├── JsonDescriptor.php.bin│   ├── MarkdownDescriptor.php.bin│   ├── TextDescriptor.php.bin│   └── XmlDescriptor.php.bin├── Formatter│   ├── OutputFormatterInterface.php.bin│   ├── OutputFormatter.php.bin│   ├── OutputFormatterStyleInterface.php.bin│   ├── OutputFormatterStyle.php.bin│   └── OutputFormatterStyleStack.php.bin├── Helper│   ├── DebugFormatterHelper.php.bin│   ├── DescriptorHelper.php.bin│   ├── DialogHelper.php.bin│   ├── FormatterHelper.php.bin│   ├── HelperInterface.php.bin│   ├── Helper.php.bin│   ├── HelperSet.php.bin│   ├── InputAwareHelper.php.bin│   ├── ProcessHelper.php.bin│   ├── ProgressHelper.php.bin│   ├── QuestionHelper.php.bin│   ├── TableHelper.php.bin│   ├── Table.php.bin│   └── TableStyle.php.bin├── Input│   ├── ArgvInput.php.bin│   ├── ArrayInput.php.bin│   ├── InputArgument.php.bin│   ├── InputAwareInterface.php.bin│   ├── InputDefinition.php.bin│   ├── InputInterface.php.bin│   ├── InputOption.php.bin│   └── Input.php.bin└── Output├── ConsoleOutputInterface.php.bin├── ConsoleOutput.php.bin├── NullOutput.php.bin├── OutputInterface.php.bin├── Output.php.bin└── StreamOutput.php.bin32 级目录, 87 个文件
✔ 抽象语法树!!
    echo substr("abc", [1,2]);
    % phan -a test.phpAST_STMT_LIST @ 10: AST_STMT_LIST @ 20: AST_ECHO @ 20: AST_CALL @ 20: AST_NAME @ 2flags: NAME_NOT_FQ (1)0: "substr"1: AST_ARG_LIST @ 20: "abc"1: AST_ARRAY @ 20: AST_ARRAY_ELEM @ 2flags: 00: 11: null1: AST_ARRAY_ELEM @ 2flags: 00: 21: null
    % phan -a test.phptest.php:2 TypeError arg#2(start) is int[] but substr() takes int
✔ 返回类型
function get_config(): array {return 42;
}
get_config();// 可捕获的致命错误:get_config() 的返回值必须是数组类型,此处返回了整数。
✔ 强制标量类型
function logmsg(string $msg, int $level, float $severity) {var_dump($msg);      // string(1) "1"var_dump($level);    // int(2)var_dump($severity); // float(3)
}
logmsg(1, "2.5", 3);
✔ 严格标量类型
declare(strict_types=1);logmsg(1, "2.5", 3);
致命错误:传给 logmsg() 的首个参数必须是字符串类型,此处是整型。
✔ 匿名类
return new class($controller) implements Page {public function __construct($controller) {/* ... */}/* ... */
};class MyObject extends MyStuff {public function getInterface() {return new class implements MyInterface {/* ... */};}
}
✔ Null 合并操作符
$a = NULL;
$b = 1;
$c = 2;echo $a ?? $b; // 1
echo $c ?? $b; // 2
echo $a ?? $b ?? $c; // 1
echo $a ?? $x ?? $c; // 2
✔ 飞船操作符 (Spaceship Operator)
|=|  Tie Fighter
k=k  Tie Interceptor
<==> Tie Bomber  
<=>  Tie Advanced X1 ✔
function cmp_php5($a, $b) {return ($a < $b) ? -1 : (($a >$b) ? 1 : 0);
}function cmp_php7($a, $b) {return $a <=> $b;
}
✔ 致命错误中的特例
function call_method($obj) {$obj->method();
}call_method(null);
// 致命错误:非对象调用了成员函数 method()
try {call_method(null);
} catch (EngineException $e) {echo "Exception: {$e->getMessage()}\n";
}
// Exception: Call to a member function method() on a non-object
//特例:非对象调用了成员函数 method()
✔ 零成本断言
function test($arg) {assert($arg > 20 && $arg < 110, "$arg is invalid");
}
ini_set('zend.assertions',0); test(16);
ini_set('zend.assertions',1); test(17);
ini_set('assert.exception',1); test(18);
Warning: assert(): 17 is invalid failed in /home/rasmus/assert.php on line 3
Fatal error: Uncaught AssertionError: 18 is invalid in /home/rasmus/assert.php:3
Stack trace:
#0 /home/rasmus/assert.php(3): assert(false, '18 is invalid')
#1 /home/rasmus/assert.php(13): test(18)
#2 {main}thrown in /home/rasmus/assert.php on line 3    
; Completely skip compiling assert() calls
; (can only be set in php.ini)
zend.assertions = -1
✔ 新增 Closure::call()
$f = function () {return $this->n;
};
class MyClass {private $n = 42;
}
$myC = new MyClass;
$c = $f->bindTo($myC, "MyClass");
$c();
$f = function () {return $this->n;
};
class MyClass {private $n = 42;
}
$myC = new MyClass;
$f->call($myC);
✔ 移除诸多弃用功能
 (PHP 4 代码将会崩溃!)
- ext/ereg (use ext/pcre instead)
- preg_replace() eval modifier (use preg_replace_callback() instead)
- ext/mysql (use ext/mysqli or ext/pdo_mysql instead)
- Assignment of new by reference
- Scoped calls of non-static methods from incompatible $this context- dl() in php-fpm
- set_magic_quotes_runtime() and magic_quotes_runtime()
- set_socket_blocking() (use stream_set_blocking() instead)
- mcrypt_generic_end() (use mcrypt_generic_deinit() instead)
- mcrypt_ecb, mcrypt_cbc, mcrypt_cfb and mcrypt_ofb (use mcrypt_encrypt() and mcrypt_decrypt() instead)
- datefmt_set_timezone_id() and IntlDateFormatter::setTimeZoneID() (use datefmt_set_timezone() or IntlDateFormatter::setTimeZone() instead)- xsl.security_prefs (use XsltProcessor::setSecurityPrefs() instead)
- iconv.input_encoding, iconv.output_encoding, iconv.internal_encoding,mbstring.http_input, mbstring.http_output and mbstring.internal_encoding(use php.input_encoding, php.internal_encoding and php.output_encoding instead)- $is_dst parameter of the mktime() and gmmktime() functions
- # style comments in ini files (use ; style comments instead)
- String category names in setlocale() (use LC_* constants instead)
- Unsafe curl file uploads (use CurlFile instead)
- PDO::PGSQL_ATTR_DISABLE_NATIVE_PREPARED_STATEMENT driver option (use PDO::ATTR_EMULATE_PREPARES instead)
- CN_match and SNI_server_name stream context option (use peer_name instead)
✔ 新的保留字:
  • bool

  • int

  • float

  • string

  • null

  • false

  • true

  • resource

  • object

  • mixed

  • numeric

✔ Windows 系统下支持64位整数
✔ 清除边缘情况下整型溢出/下溢、
✔ 在64位版本中支持长度大于 2^31 字节的字符串
✔ 无效数值型解析错误
$mask = 0855;  // 解析错误:无效的数值型
✔ 统一变量语法
// 从左到右
$this->$belongs_to['column']
// 从右到左
$this->{$belongs_to['column']}// 支持缺失的操作组合
$foo()['bar']()
[$obj1, $obj2][0]->prop
getStr(){0}// 支持嵌套的 ::
$foo['bar']::$baz
$foo::$bar::$baz
$foo->bar()::baz()// 支持嵌套的 ()
foo()()
$foo->bar()()
Foo::bar()()
$foo()()// 支持对任意(...)表达式的操作
(...)['foo']
(...)->foo
(...)->foo()
(...)::$foo
(...)::foo()
(...)()// 针对上一点,两个更加实用的例子
(function() { ... })()
($obj->closure)()// 支持对 dereferencable 标量的所有操作
// (用处不是很大)
"string"->toLower()
[$obj, 'method']()
'Foo'::$bar
echo preg_replace('/:-:(.*?):-:/e', '$this->pres->\\1', $text);
echo preg_replace_callback('/:-:(.*?):-:/', function($matches) {return $this->pres->$matches[1]; // Oops!},$text);
% phan -b display.php
Files scanned: 1
Time:        0.13s
Classes:    8
Methods:    55
Functions:    5
Closures:    5
Traits:        0
Conditionals:    307
Issues found:    1display.php:416 CompatError expression may not be PHP 7 compatible
echo preg_replace_callback('/:-:(.*?):-:/', function($matches) {return $this->pres->{$matches[1]}; // Ok},$text);

✔ Unicode 码点转义语法

echo "\u{202E}Right-to-left text";echo "\u{1F602}";

‮Right-to-left text?

✔ ICU IntlChar 类加入 intl 扩展


通用版本预计在2015年10月发布


针对 Wordpress-3.6.0 首页100次请求的耗时与机器指令数量

  • zval 的大小从24字节减小到16字节

  • 哈希表大小从72字节减小到56字节

  • 哈希表 bucket 大小从72字节减小到32字节

  • 定长数组优化

$a = [];
for($i=0; $i < 100000;$i++) $a[] = ['abc'];
echo memory_get_usage(true);
// PHP 5.x  43M
// PHP 7.0  6M
  • CPU 缓存更大更友好

  • 与 jemalloc 相似的内存分配器

  • 更快的哈希表迭代 API

  • 数组复制优化

  • 默认启用 PCRE JIT

  • 快速的 ZPP (ZendParseParameters) 执行

  • 更快的栈分配 zvals(而不是堆)

  • 优化的 VM 调用

  • gcc 4.8+ 中的全局寄存器变量

  • 加上数百处微优化

运行时编译执行(JIT)?

谎话,弥天大谎,还有基准测试

测试箱规格

  • Gigabyte Z87X-UD3H i7-4771 4 cores @ 3.50GHz w/ 16G of Ram @ 1600MHz

  • 启用超线程的八个虚拟核

  • Toshiba THNSNHH256GBST SSD

  • Linux debian 3.16.0-4-amd64 #1 SMP Debian 3.16.7-ckt9-2 (2015-04-13) x86_64 GNU/Linux

  • MySQL 5.6.24

  • 如无特别指出,所有测试使用 nginx-1.6.2 + php-fpm

  • 本地 100Mbps 网络连接

  • 对独立机器进行围攻基准测试(siege benchmark)

所有 PHP 版本均在本地使用 gcc-4.9.2 -O2 编译

配置标志

./configure --disable-debug       --with-apxs2=/usr/bin/apxs2 \--enable-zend-signals --with-gd \--without-pear        --with-jpeg-dir=/usr \--with-png-dir=/usr   --with-vpx-dir=/usr \--with-t1lib=/usr     --with-freetype-dir=/usr \--enable-exif         --enable-gd-native-ttf \--with-zlib           --with-mysql=/usr \--with-gmp            --with-zlib-dir=/usr \--with-gettext        --with-kerberos \--with-imap-ssl       --with-mcrypt=/usr/local \--with-iconv          --enable-sockets \--with-openssl        --with-pspell \--with-pdo-sqlite     --with-pdo-mysql=mysqlnd \--enable-soap         --enable-xmlreader \--enable-phar=shared  --with-xsl \--enable-ftp          --enable-cgi \--with-curl=/usr      --with-tidy \--with-xmlrpc         --enable-mbstring \--enable-sysvsem      --enable-sysvshm \--enable-shmop        --with-readline \--enable-pcntl        --enable-fpm \--enable-intl         --enable-zip \--with-imap           --with-mysqli=mysqlnd \--enable-calendar     --prefix=/usr/local \--with-mysql-sock=/var/run/mysqld/mysqld.sock \--with-config-file-scan-dir=/etc/php7/conf.d \--with-config-file-path=/etc/php7

php.ini

[PHP]
zend.multibyte=On
date.timezone="America/Los_Angeles"
display_startup_errors=On
zend.enable_gc=Off
include_path="/usr/local/lib/php"
default_charset="UTF-8"
error_reporting=-1variables_order=GPCS
sendmail_path=""max_execution_time=60
memory_limit=512M
post_max_size=1024M
cgi.force_redirect=0
cgi.fix_pathinfo=1magic_quotes=0
magic_quotes_gpc=0
user_ini.filename=
realpath_cache_size=2M
cgi.check_shebang_line=0max_input_vars=1000
max_file_uploads=50zend_extension=opcache.so
opcache.enable=1
opcache.memory_consumption=256
opcache.interned_strings_buffer=8
opcache.max_accelerated_files=10000
opcache.revalidate_freq=60
opcache.fast_shutdown=1
opcache.enable_cli=1

php-fpm.d/www.conf

[www]
user = www-data
group = www-data
listen = /var/run/php-fpm.sock
listen.owner = www-data
listen.group = www-data
listen.mode = 0660pm = static
pm.max_children = 10
pm.status_path = /status
ping.path = /ping
ping.response = pong

nginx.conf

user www-data;
worker_processes 4;
pid /var/run/nginx.pid;events {worker_connections 768;
}http {sendfile on;tcp_nopush on;tcp_nodelay on;keepalive_timeout 65;types_hash_max_size 2048;include /etc/nginx/mime.types;default_type application/octet-stream;access_log /var/log/nginx/access.log;error_log /var/log/nginx/error.log;gzip on;gzip_disable "msie6";include /etc/nginx/conf.d/*.conf;include /etc/nginx/sites-enabled/*;
}

php.conf

location ~ \.php {include                  fastcgi_params;fastcgi_keep_conn        on;fastcgi_index            index.php;fastcgi_split_path_info  ^(.+\.php)(/.+)$;fastcgi_param PATH_INFO  $fastcgi_path_info;fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;fastcgi_intercept_errors on;fastcgi_pass             unix:/var/run/php-fpm.sock;
}

hhvm.conf

location ~ \.php$ {include           fastcgi_params;fastcgi_keep_conn on;fastcgi_pass      unix:/var/run/hhvm/server.sock;fastcgi_index     index.php;fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
}

sites-enabled/wordpress

server {listen 80;server_name wordpress;root /var/www/wordpress;access_log /var/log/nginx/wordpress-access.log;error_log /var/log/nginx/wordpress-error.log;location / {index     index.html index.htm index.php;autoindex on;}location ~ /\.  { return 403; }include backend.conf;
}

HipHop VM 3.7.0 (rel) from http://dl.hhvm.com/ubuntu

server.ini
pid = /var/run/hhvm/pid
hhvm.server.file_socket = /var/run/hhvm/server.sock
hhvm.server.type = fastcgi
hhvm.server.default_document = index.php
hhvm.log.use_log_file = true
hhvm.log.file = /var/log/hhvm/error.log
hhvm.repo.central.path = /var/run/hhvm/hhvm.hhbc
php.ini
session.save_handler = files
session.save_path = /var/lib/php5
session.gc_maxlifetime = 1440hhvm.log.level = Warning
hhvm.log.always_log_unhandled_exceptions = true
hhvm.log.runtime_error_reporting_level = 8191
hhvm.mysql.typed_results = false

Drupal 8-git

Wordpress-4.1.1

http://wordpress/?p=1

GCC 反馈制导优化(Feedback-Directed Optimization, FDO)

$ make clean
$ make -j8 prof-gen
...
$ sapi/cgi/php-cgi -T 1000 /var/www/wordpress/index.php > /dev/null
$ make prof-clean
$ make -j8 prof-use

Wordpress-4.1.1

http://wordpress/?p=1

phpBB 3.1.3

http://phpbb/viewforum.php?f=2

MediaWiki 1.24.1

默认首页

Opencart 2.0.2.0

默认安装下的首页

WardrobeCMS 1.2.0

包含一篇短文的首页

Geeklog 2.1.0

默认首页

Magento-1.9.1.1

http://magento/index.php/sale.html (sample data)

Traq 3.5.2

http://traq/test/tickets/1

Had to fix one line of code in the Avalon database library:

diff --git a/database/model.php b/database/model.php
index 6c5f7da..c93e726 100644
--- a/database/model.php
+++ b/database/model.php
@@ -397,7 +397,7 @@ public function __get($var) {$belongs_to['column'] = $var . '_id';}$model = $belongs_to['model'];
-      return $this->$var = $model::find($belongs_to['foreign_key'], $this->$belongs_to['column']);
+      return $this->$var = $model::find($belongs_to['foreign_key'], $this->{$belongs_to['column']});} else {$val = $this->$var;

Cachet

包含一件事件的首页

Moodle-2.9-dev

点击默认的首页

ZenCart 1.5.4

包含演示数据的首页

OneAPM for PHP 能够深入到所有 PHP 应用内部完成应用性能管理和监控,包括代码级别性能问题的可见性、性能瓶颈的快速识别与追溯、真实用户体验监控、服务器监控和端到端的应用性能管理。

帮我们一起测试!

它真的简单易用!

安装 Vagrant 与 Virtualbox

之后:

$ git clone https://github.com/rlerdorf/php7dev.git$ cd php7dev$ vagrant up
... (takes a bit - it is downloading 1.5G)$ vagrant ssh

它会 NAT, DHCP 并产生固定的地址 192.168.7.7

http://192.168.7.7/ 会展示 PHP 7 的 phpinfo() 页面。

现在,你的开发环境就部署好啦。

切换 PHP 版本比较繁杂:

vagrant@php7dev:~$ newphp 56
Activating PHP 5.6.6-dev and restarting php-fpmvagrant@php7dev:~$ newphp 7 debug
Activating PHP 7.0.0-dev and restarting php-fpm

20 个预编译的版本

/usr/local/php53            /usr/local/php54-zts        /usr/local/php56-debug-zts
/usr/local/php53-debug      /usr/local/php55            /usr/local/php56-zts
/usr/local/php53-debug-zts  /usr/local/php55-debug      /usr/local/php70
/usr/local/php53-zts        /usr/local/php55-debug-zts  /usr/local/php70-debug
/usr/local/php54            /usr/local/php55-zts        /usr/local/php70-debug-zts
/usr/local/php54-debug      /usr/local/php56            /usr/local/php70-zts
/usr/local/php54-debug-zts  /usr/local/php56-debug

构建任意版本:

$ makephp 7
Build log in /tmp/build.log
Building PHP 7.0
configuring...
compiling...
installing...
done
Building PHP 7.0-debug
configuring...
compiling...
installing...
done

或手动地

$ cd php-src
$ git checkout PHP-5.6
$ git pull -r
$ make distclean
$ ./buildconf -f
$ ./cn56
$ make
$ sudo make install

github.com/rlerdorf/php7dev

请向我们提交 bug!

原文链接 http://talks.php.net/taiwan15

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/295959.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mvc教程

第一章 mvc概述 入门 需要安装 Visual Studio 2008 或 Visual Web Developer 2008 Express 来构建 ASP.NET MVC 应用程序。还需要下载 ASP.NET MVC Framework。 如果没有 Visual Studio 2008&#xff0c;可以从下面的网址下载 90 天试用版&#xff1a; http://msdn.microsoft.c…

windows下面怎么github ssh 公钥,然后克隆项目

windos下面怎么github ssh 公钥,然后克隆项目 第一步、 1. 安装git,从程序目录打开 "Git Bash" 2. 键入命令:ssh-keygen -t rsa -C "email@email.com" 我的邮箱是chen_yu@kuyu.com , "email@email.com"是github账号 3. 提醒你输入key的…

连破四次吉尼斯世界纪录!厨师界再出神人,用一公斤拉面缔造了一代传奇,背后却是简单的原理……

全世界只有3.14 % 的人关注了爆炸吧知识超模君最喜欢的就是公司楼下海底捞火锅面。不仅是面确实好吃&#xff0c;更重要的是因为海底捞拉面小哥的技艺十分精湛&#xff01;提臀、收腹&#xff0c;只见拉面小哥化身蹦迪达人&#xff0c;在旋转跳跃中舞动拉面。一顿猛如虎的操作之…

微软推出 .NET 官方社区论坛

James 近日发布博客&#xff08;https://devblogs.microsoft.com/dotnet/introducing-the-net-tech-community-forums/&#xff09;&#xff0c;推出 .NET 官方社区论坛&#xff0c;为开发者提供一个官方的交流平台&#xff0c;小道消息&#xff0c;微软即将上线中文版的.NET网…

android sdk中添加自定义api,android SDK中添加自定义api【转】

本文的思路&#xff1a;android APP调用自定义java API,自定义java API调用自定义jni接口1&#xff1a;在android源码目录framework/base下面创建add目录add目录里面的结构如下&#xff1a;里面的Nadd.java android_jnitest_Nadd.cpp 和Android.mk内容如下&#xff1a;Nadd.jav…

远程控制利器TeamViewer使用教程(图)

TeamViewer是什么&#xff1f; 他是一款免费的可以穿透内网的远程控制软件&#xff0c;可以实现桌面共享&#xff0c;文件传送等功能&#xff0c;简单一点说就是和QQ远程协助一样&#xff0c;但是比QQ的远程协助功能更为强大。 TeamViewer与木马有什么区别&#xff1f; 说到远程…

千万别让男朋友穿你的短裙......

1 工作太辛苦&#xff0c;我要走了...▼2 应该很有效&#xff1f;▼3 疑车有据&#xff01;&#xff01;▼4 这是一部色魔功法...▼5 穿上女友的衣服居然毫无违和感▼视频来源见水印&#xff0c;侵删6 整挺好&#xff01;▼7 这只有熊猫可以驾驭得了......▼你点的每个赞&…

迎接.NET 6,《dotnet+Linux中文手册》完整PDF开放下载!

昨晚已经正式发布了.NET6,具体参见&#xff1a;https://devblogs.microsoft.com/dotnet/announcing-net-6/。这是.NET团队和社区努力一年的成果&#xff0c;C# 10 和 F# 6 有很大的语言改进&#xff0c;使代码更简单、更好。性能有了巨大的提升&#xff0c;我们看到微软的云服务…

常用MIME类型(Flv,Mp4的mime类型设置)

也许你会在纳闷&#xff0c;为什么我上传了flv或MP4文件到服务器&#xff0c;可输入正确地址通过http协议来访问总是出现“无法找到该页”的404错误呢&#xff1f;这就表明mp4格式文件是服务器无法识别的&#xff0c;其实&#xff0c;这是没有在iis中将相应的MIME类型进行设置的…

史上四大“杀人”建筑,烧掉几百亿,却犯低级错误,网友:有钱人的智商,我不懂

全世界只有3.14 % 的人关注了爆炸吧知识本文转自普象工业设计小站这个世界上有多少荒谬的建筑&#xff1f;国内土味审美的大楼只是冰山一角在更多的国家里耗费巨资&#xff0c;却无比失败的工程比土味大楼更多更荒唐你也许听说过美国这座会跳舞的大桥耗资千万&#xff0c;由优秀…

迎.NET6,今日先送200P全新视频教程 / 源码

昨晚已经正式发布了.NET6,具体参见&#xff1a;https://devblogs.microsoft.com/dotnet/announcing-net-6/。这是.NET团队和社区努力一年的成果&#xff0c;C# 10 和 F# 6 有很大的语言改进&#xff0c;使代码更简单、更好。性能有了巨大的提升&#xff0c;我们看到微软的云服务…

android 横向stepview,Android 流程指示器 StepView

软件介绍StepView 是Android平台下自定义的流程指示器。效果图&#xff1a;使用:android:id"id/step_view0"android:layout_width"match_parent"android:layout_height"wrap_content"android:layout_centerInParent"true"android:text…

58年前,这3个人在“撕逼”中拿下诺贝尔奖!一起研究DNA的女科学家却痛苦去世.........

全世界只有3.14 % 的人关注了爆炸吧知识人类的本质是双螺旋结构1953年4月25日&#xff0c;《自然》杂志发表了一篇不到千字的论文&#xff1a;消息一出&#xff0c;便掀起了科学界的轩然大波。因为这篇短小精悍的论文史无前例地揭示了正确的DNA立体结构。图片仅供参考&#xff…

Azure App Service 上的根证书

点击上方蓝字关注“汪宇杰博客”原文&#xff1a;Amol Mehrotra翻译&#xff1a;Edi Wang导语App Service 有一个受信任的根证书列表&#xff0c;您不能在 App Service 的多租户版本中修改这些证书&#xff0c;但您可以在应用服务环境 (ASE) 的受信任根存储中加载自己的 CA 证书…

jettytomcat对待表单过长问题

为什么80%的码农都做不了架构师&#xff1f;>>> 结论两句话&#xff1a; tomcat知道自己处理不了了&#xff0c;什么也不干过去了 jett知道自己处理不了了&#xff0c;抛个IllegalStateException出来通知一下 jetty默认允许的content-length2001000 org.eclips…

Android之Adapter用法总结

Android之Adapter用法总结 Adapter是连接后端数据和前端显示的适配器接口,是数据和UI(View)之间一个重要的纽带。在常见的View(ListView,GridView)等地方都需要用到Adapter。如下图直观的表达了Data、Adapter、View三者的关系: Android中所有的Adapter一览: …

那些年,画家发明的黑科技

全世界只有3.14 % 的人关注了爆炸吧知识在现代摄影技术发明之前&#xff0c;获取图像的最佳方式只有绘画。在绘画的时代&#xff0c;如何把事物画的逼真&#xff0c;几乎成为了困扰画家一生的问题。为了准确展现客观世界&#xff0c;让画面看起来更加逼真&#xff0c;古代的艺术…

Android jdwp 自动断开,开启debug调试模式,进入不了,等一会就闪退了!!!!

原因&#xff1a;debug标记加多了art/runtime/jdwp/jdwp_event.cc:661] Check failed: Thread::Current() ! GetDebugThread() (Thread::Current()0xe1908400, GetDebugThread()0xe1908400) Expected event thread11-16 15:29:18.457 10331-10339/包名 A/art: art/runtime/runt…

Visual Studio 2022发布了,我最爱的5大特性

VS2022今天Visual Studio 2022 终于发布了&#xff0c;你只需要按下⾯地址就可以快速安装你所需要的Visual Studio 2022版本&#xff0c;包括了企业版本&#xff0c;专业版本&#xff0c;以及社区版本。请输入以下⽹址安装最新的Visual Studio 2022 https://aka.ms/InstallVS或…

ASP.NET3.5 企业级项目开发 -- 第二章 数据访问层(DAL)的开发

为什么80%的码农都做不了架构师&#xff1f;>>> ASP.NET3.5 企业级项目开发 &#xff0d;&#xff0d; 第二章 数据访问层(DAL)的开发 前言&#xff1a;本篇主要讲述数据访问层的开发&#xff0c;而且为了大家交流&#xff0c;已经创建企业项目开发团队&…